《access数据库应用教程使用查询.pptx》由会员分享,可在线阅读,更多相关《access数据库应用教程使用查询.pptx(121页珍藏版)》请在taowenge.com淘文阁网|工程机械CAD图纸|机械工程制图|CAD装配图下载|SolidWorks_CaTia_CAD_UG_PROE_设计图分享下载上搜索。
1、学习目标学习目标 查询是Access组织和提取数据的一种重要手段。使用查询,可以将多个表或查询中的数据组织到一起,为应用程序服务。本章将在介绍查询基础知识的同时,重点讲解如何使用查询向导和查询设计器创建查询。第1页/共121页本章要点本章要点 查询基础查询设计器查询向导查询中的运算符和函数高级查询第2页/共121页查查 询询 基基 础础 理解查询 查询类型 查询设计工具 SQL Select语句 表联接类型第3页/共121页理解查询理解查询 查询可从一个或多个表中检索数据,并可执行各种统计,如求最大值、最小值、总计、计数和平均值等。查询本质上是SQL Select语句。执行查询时,Access
2、会将表或查询中的数据提取出来,显示在数据表中。数据表中的记录称为动态集。动态集是动态的记录集合,实际的数据保存在数据库的表中。它与表类似,但不是表。Access不会保存动态集,每次在运行查询时,都从底层的表中读取数据并重建动态集,所以动态集中的数据始终是最新的。在保存查询时,Access保存的是查询的结构:使用的表、字段、排序规则、筛选条件和查询类型等。第4页/共121页查询类型查询类型 Access提供了多种查询,包括选择查询、参数查询、交叉表查询、操作查询和SQL查询。选择查询参数查询 交叉表查询操作查询 操作查询 第5页/共121页选择查询选择查询 选择查询是最简单的一种查询,用于从一个
3、或多个表中提取需要的字段,也可将数据的更新返回底层的表。在选择查询中,还可使用条件(也称查询准则)来限制查询结果。查询准则对应SQL Select语句中的WHERE和HAVING子句。第6页/共121页参数查询参数查询 参数查询在执行时要求输入查询参数,然后按照输入内容执行数据检索。如使用参数查询检索指定班级的学生人数。第7页/共121页交叉表查询交叉表查询 交叉表查询只用一个表或查询作为数据源,从中返回某个字段的统计值(合计、计算或平均值),并将它们分组,一组列在数据表的左侧,一组列在数据表的上部。第8页/共121页操作查询操作查询 操作查询用于对多个记录执行批量更新操作,Access共有4
4、种类型的操作查询:删除查询、更新查询、追加查询与生成表查询。删除查询删除查询用于对一个或多个表中满足条件的一组记录进行删除操作。如使用删除查询删除在“选课记录”表中出现的无效学号的选课记录。第9页/共121页操作查询操作查询更新查询更新查询用于对一个或多个表中记录的某些字段执行更新。如将所有学生的成绩统一加10分。追加查询追加查询用于将查询结果添加到其他的表中。生成表查询生成表查询使用查询结果创建新的表。第10页/共121页SQLSQL查询查询SQL查询指用户直接使用SQL语句创建的查询,这类查询通常不能直接在查询设计器中通过图形化的方式创建。SQL查询包括4种方式:联合查询、传递查询、数据定
5、义查询和子查询。联合查询联合查询将多个查询结果合并到一起。第11页/共121页SQLSQL查询查询传递查询传递查询指基于远程数据库上的SQL语句进行的查询。这种查询可在不建立连接的情况下直接对服务器中的表进行操作。在Access中,可用ADO对象替代传递查询。数据定义查询数据定义查询指使用SQL的数据定义语言(DDL)在查询过程中创建、删除、更改表或创建数据库中的索引。第12页/共121页SQLSQL查询查询子查询SQL的子查询指嵌套在其他查询中的SQL Select语句。第13页/共121页查询设计工具查询设计工具Access提供了多种查询设计工具,包括查询设计器、简单查询向导、交叉表查询向
6、导、查找重复项查询向导和查找不匹配项查询向导等。查询设计器 简单查询向导 交叉表查询向导 查找重复项查询向导 查找不匹配项查询向导 第14页/共121页查询设计器查询设计器 在查询的“设计视图”中打开的就是“查询设计器”。使用“查询设计器”可创建各种类型的查询。在创建查询,通常先使用向导创建查询,然后在“查询设计器”中进行修改。第15页/共121页简单查询向导简单查询向导 “简单查询向导”使用一个或多个表或查询作为数据源,可对记录分组,或执行求最大值、最小值、总计、计数和平均值等计算。“简单查询向导”不能设置条件筛选记录。第16页/共121页交叉表查询向导交叉表查询向导 “交叉表查询向导”用于
7、创建交叉表查询,对记录计算总计、平均值、计数或其他类型总计,然后按照两类信息对结果进行分组:一组信息分布在数据表的左侧,另一组分布在数据表的顶端。第17页/共121页查找重复项查询向导查找重复项查询向导 “查找重复项查询向导”创建的查询为选择查询,在查询结果中返回重复的记录。如在“选课记录”表中查询是否有学生重复选择了同一门课。第18页/共121页查找不匹配项查询向导查找不匹配项查询向导 “查找不匹配项查询向导”也用于创建选择查询,用于查找与其他表不相关的记录。如查找没有选课的学生信息。第19页/共121页SQL SelectSQL Select语句语句在使用设计器或向导创建查询时,Acces
8、s将查询转换为SQL Select语句。在查询的“SQL视图”中可查看查询的SQL Select语句。SQL Select基本结构 SELECT子句 使用INTO子句创建新表 使用FROM子句指定数据源 使用WHERE子句定义筛选条件 使用GROUP BY子句对记录分组 使用ORDER BY子句对结果排序 使用联合查询 使用子查询 第20页/共121页SQL SelectSQL Select基本结构基本结构SELECT语句的完整语法较复杂,其基本结构如下:SELECT select_listINTO new_table_nameFROM table_listWHERE search_condi
9、tionsGROUP BY group_by_listHAVING search_conditionsORDER BY order_list ASC|DESC 第21页/共121页SQL SelectSQL Select基本结构基本结构SELECT语句基本结构中包含了7个子句,这些子句的排列顺序是固定的。其中除SELECT子句外,其他子句都可省略,但若出现,则必须按照基本结构中的顺序排列。SELECT语句中各个子句的作用分别如下:SELECT子句指定出现在查询结果中的字段,其中select_list为选择包含在查询结果中的字段列表,多个字段之间使用逗号分隔。第22页/共121页SQL Sele
10、ctSQL Select基本结构基本结构INTO子句指定使用查询结果来创建新表,其中new_table_name指定新表的名称。FROM子句指定查询结果中数据的来源。这些来源可能包括表、查询或链接表。WHERE子句指定源表中记录的筛选条件,只有符合条件的记录中的字段才可能出现在查询结果中。第23页/共121页SQL SelectSQL Select基本结构基本结构GROUP BY子句指定在执行查询时,对记录的分组条件,其中在SELECT子句的select_list列表的字段必须包含在group_by_list中。HAVING子句指定查询结果的附加筛选。逻辑上讲,HAVING子句从中间结果对记录
11、进行筛选,这些中间结果是用SELECT语句中的FROM、WHERE或GROUP BY子句创建的。HAVING子句通常与GROUP BY子句一起使用,尽管HAVING子句前面不必有GROUP BY子句。第24页/共121页SQL SelectSQL Select基本结构基本结构ORDER BY子句指定查询结果中记录的排列顺序。order_list指定用于排列记录的字段列表,ASC和DESC关键字用于指定记录是按升序还是按降序排序。第25页/共121页SELECTSELECT子句子句SELECT子句的作用是从数据源表中选择包含在查询结果中的字段,其语法格式如下:SELECT ALL|DISTINC
12、T|DISTINCTROW TOP n PERCENT *|表名.*|字段名 AS 输出名称使用*返回所有字段SELECT子句中,*表示从FROM子句指定表中返回所有字段,各字段按表中的顺序返回。第26页/共121页SELECTSELECT子句子句直接指定字段名如果只返回表中的部分字段,可在SELECT子句中直接列出字段名称,多个字段使用逗号分隔。例如,下面的查询返回“学生信息”表中所有学生的姓名和学号:SELECT姓名,学号 FROM 学生信息如果返回字段出现在多个表中,则必须在字段名之前加上表名进行限定。定义字段输出名称查询结果输出的字段默认与原字段名称相同,可用AS指定字段的输出名称。第
13、27页/共121页SELECTSELECT子句子句在查询结果中输出唯一记录在SELECT子句中,可用ALL或DISTINCT关键字指定是否输出重复记录。默认为ALL,即输出重复记录;DISTINCT表示不输出重复记录。DISTINCTROW关键字与DISTINCT类似,DISTINCT用于限制查询结果中的各个字段必须是唯一的,DISTINCTROW则进一步限制记录必须是唯一的,忽略掉重复记录。第28页/共121页SELECTSELECT子句子句使用TOP控制返回的记录数量在SELECT子句中,可用TOP n返回前n条记录。n是0,294967295范围内的整数。如果加上PERCENT关键字,则
14、表示返回前百分之n条记录。此时,n必须是0,100范围内的整数。第29页/共121页使用使用INTOINTO子句创建新表子句创建新表INTO子句的语法格式如下:INTO 新表名称INTO子句使用查询结果创建新表。第30页/共121页使用使用FROMFROM子句指定数据源子句指定数据源 FROM子句的语法格式如下:FROM 表名 INNER|LEFT|RIGHT JOIN 表名ON 条件FROM子句一般只需指定源表或查询的名称,多个源表或查询用逗号分隔。JOIN关键字用于指定联接类型。INNER JOIN表示内部联接,若使用内部联接,INNER关键字可以省略。LEFT JOIN表示左外联接,RI
15、GHT JOIN表示右外联接。若不指定联接类型,则为交叉联接。ON关键字指定联接的条件,其格式如下:ON 表名1.字段名1 运算符 表名2.字段名2运算符包括=(大于)、(大于)、=(大于等于)和(不等)。第31页/共121页使用使用WHEREWHERE子句定义筛选条件子句定义筛选条件 WHERE子句的语法如下:WHERE 筛选条件筛选条件是一个有效的逻辑表达式。第32页/共121页使用使用GROUP BYGROUP BY子句对记录分组子句对记录分组 GROUP BY子句语法格式如下:GROUP BY 分组字段列表 GROUP BY子句对记录进行分组,从而实现SELECT子句中统计函数(如SU
16、M、COUNT、MIN、MAX和AVG等)的分类计算。第33页/共121页使用使用ORDER BYORDER BY子句对结果排序子句对结果排序ORDER BY子句的语法格式如下:ORDER BY 排序字段1 ASC|DESC ,.n ASC表示升序,DESC表示降序,默认为ASC。Access允许指定多个排序字段,其间需用逗号分隔。第34页/共121页使用联合查询使用联合查询联合查询指使用UNION运算将多个查询结果合并到一起,其语法格式如下:SELECT语句1UNIONSELECT语句2用UNION合并两个查询必须满足如下条件:输出字段的数目必须相同。对应字段的数据类型必须兼容,即在数据类型
17、不同时,可相互转换。在合并后的查询结果中,字段名称为第一个查询中的字段名称,其他查询的字段名称被忽略。在转换不同类型的对应字段值时,以“容纳最多数据”为基本原则。第35页/共121页使用子查询使用子查询 子查询指嵌套在其他SQL语句中的SELECT语句,如嵌套在SELECT、INSERT、UPDATE、DELETE语句或其他子查询中。任何允许使用表达式的地方都可使用子查询。子查询也称为内部查询或内部选择,而包含子查询的语句也称为外部查询或外部选择。通常,子查询作为外部选择的选取条件或者数据来源。(1)子查询与SELECT语句的使用语法完全相同,但在使用时必须遵守以下原则:子查询语句使用括号()
18、括起来。第36页/共121页使用子查询使用子查询在比较运算中使用的子查询的输出字段最多一个字段。若外部查询的WHERE子句包括某个字段,则该子句中使用的子查询选择列表中该字段的数据类型必须兼容(在不同时可相互转换)。使用了GROUP BY的子查询不能使用DISTINCT关键字。只有在子查询中使用了TOP关键字时,才可以使用ORDER BY子句。第37页/共121页使用子查询使用子查询(2)子查询的返回结果可分为3种:单一值、单列的多行数据和多列的多行数据。这3种返回结果对应了不同的使用方法:直接使用单一的返回结果。例如使用在=、等关系表达式或+、-、*、/等算术表达式中。使用单列的多行数据作为
19、比较清单。通常使用在IN、ALL或ANY(SOME)运算中,判断某个值是否在比较清单中,运算结果为TRUE或FALSE。使用多列的多行数据作为测试条件,即使用EXISTS判断是否有返回值,运算结果为TRUE或FALSE。第38页/共121页使用子查询使用子查询(3)下面通过具体的查询实例来说明子查询的使用。直接使用单一的返回结果使用单列的多行数据作为比较清单作为比较清单的子查询通常用在SELECT、INSERT、UPDATE和DELETE等语句中的WHERE或HAVING子句的逻辑表达式中,并且多使用IN、ALL或ANY(SOME)运算。第39页/共121页使用子查询使用子查询使用多列的多行数
20、据作为测试条件在查询中,可使用EXISTS运算来测试子查询中是否有任何返回结果,如果有返回结果,则运算结果为TRUE,否则为FALSE。第40页/共121页表联接类型表联接类型联接类型用于控制从两个表返回的查询结果,Access支持4种联接:内部联接、左外联接、右外联接和交叉联接。内部联接(INNER JOIN)左外联接(LEFT JOIN)右外联接(RIGHT JOIN)交叉联接 第41页/共121页内部联接内部联接 (INNER JOIN)(INNER JOIN)内部联接是指返回两个表中联接字段值完全匹配的记录。第42页/共121页左外联接左外联接 (LEFT JOIN)(LEFT JOI
21、N)左外联接是指返回左表的全部记录,若右侧表中有匹配的记录,则用NULL代替。第43页/共121页右外联接右外联接 (RIGHT JOIN)(RIGHT JOIN)右外联接是指返回右表全部记录,若左侧表中没有匹配的记录,则用NULL代替。第44页/共121页交叉联接交叉联接 交叉联接是指没有指定联接类型的联接,将两个表中的记录一一对应。第45页/共121页查询设计器查询设计器 在“查询设计器”中可以对数据表中的任意字段进行查询,下面将详细讲解“查询设计器”的新建、结构和使用方法。打开“查询设计器”“查询设计器”结构 操作查询中的表 选择字段 设置排序方式 筛选记录 运行查询 应用举例设计“选课
22、成绩单”查询 第46页/共121页打开打开“查询设计器查询设计器”利用“查询设计器”建立查询之前,首先需将其打开,Access中常用的两种方法,即新建查询打开和打开现有查询。新建查询 打开现有查询 第47页/共121页新建查询新建查询第48页/共121页新建查询新建查询第49页/共121页新建查询新建查询第50页/共121页打开现有查询打开现有查询 第51页/共121页“查询设计器查询设计器”结构结构 “查询设计器”分为上下两部分,上半部分称为“表/查询窗格”,下半部分称为“设计网格”。第52页/共121页“查询设计器查询设计器”结构结构第53页/共121页“查询设计器查询设计器”结构结构“表
23、/查询窗格”中显示了用于设计查询的表或查询,以及表之间的关系。“设计网格”用于设计查询。在“设计网格”中,每一列都显示了一个字段的相关设置。在每列中都包含了下列内容:字段:输入或添加查询中使用的字段。表:显示字段来源表的名称。排序:设置字段是否排序以及排序方式。第54页/共121页“查询设计器查询设计器”结构结构显示:设置字段是否在查询中输出。选中该复选框,字段在查询结果中输入;取消选中该复选框,不输出字段。条件:设置字段的筛选条件。或:设置字段的其他筛选条件,允许在多个行中输入多个条件。在为查询添加条件时,每一行中各列之间的条件需要成立,而各行之间是“或者”关系,只要满足任意一行的条件即可。
24、第55页/共121页 操作查询中的表操作查询中的表 对查询中的表进行操作包括添加表、删除表、移动字段列表窗口和定义表关系与联接类型等。添加表删除表 移动字段列表窗口 定义表关系与联接类型 第56页/共121页添加表添加表在“查询设计器”中设计查询的第一步就是添加表,其操作可通过“显示表”对话框完成。在打开“查询设计器”创建新查询时,Access可自动打开“显示表”对话框。在该对话框中,可用下列方法将表添加到“查询设计器”中:在列表框中双击表或查询的名称。在列表框中单击表或查询的名称,再单击“添加”按钮。第57页/共121页添加表添加表第58页/共121页删除表删除表 若添加了某个不需要的表,可
25、先单击“表/查询窗格”中该表的字段列表窗口,然后执行下列操作将其删除:按Del键。选择“编辑/删除”命令。选择“查询/删除表”命令。用鼠标右键单击表的字段列表窗口,在弹出的快捷菜单中选择“删除表”命令。第59页/共121页移动字段列表窗口移动字段列表窗口适当调整字段列表窗口位置,可以更好的显示表之间的关系连线。同拖动其他窗口一样,拖动字段列表窗口的标题栏即可移动窗口。第60页/共121页定义表关系与联接类型定义表关系与联接类型 表关系决定了两个表的联接类型,从而决定了如何从多个表中返回记录。若已经定义了关系,在“表/查询窗格”中会显示一条连接线。如果没有定义关系,则表之间不会显示连接线,按交叉
26、联接执行查询。在“表/查询窗格”中定义关系很简单,从关系“主表”的字段列表窗口中将关联字段拖动到“子表”的关联字段上即可。第61页/共121页定义表关系与联接类型定义表关系与联接类型第62页/共121页定义表关系与联接类型定义表关系与联接类型若在查询中不需要关系,可用下列方法删除关系连接线:单击关系连接线,按Del键或选择“编辑/删除”命令。用鼠标右键单击关系连接线,在弹出的快捷菜单中选择“删除”命令。第63页/共121页定义表关系与联接类型定义表关系与联接类型关系连接线用于在查询中设置连接类型。双击关系连接线,打开“联接属性”对话框。在对话框的“左表名称”和“右表名称”下拉列表框中,可选择联
27、接中左表和右表的名称,在“左列名称”和“右列名称”下拉列表框中,可选择联接字段的名称。在对话框下方的3个选项用于设置联接类型:第64页/共121页定义表关系与联接类型定义表关系与联接类型第65页/共121页定义表关系与联接类型定义表关系与联接类型第66页/共121页选择字段选择字段 在Access中有多种方法为查询选择字段,包括选择单个字段、添加多个字段等。选择单个字段添加多个字段 添加全部字段 改变字段输出名称 使用表达式 改变字段顺序 第67页/共121页选择单个字段选择单个字段为查询选择单个字段可用下列方法:第68页/共121页选择单个字段选择单个字段从“表/查询窗格”的字段列表窗口中将
28、字段拖动到“设计网格”的“字段”行中。第69页/共121页添加全部字段添加全部字段 要添加表中的全部字段,可将字段列表窗口中的*符号添加到设计网格中,或者选择全部字段后,再将其拖动到“设计网格”中。第70页/共121页改变字段输出名称改变字段输出名称默认情况下,查询结果中字段的名称与原字段名称一致。如果要改变字段输出名称,可在“设计网格”中“字段”行显示的字段名称之前加上字段的输出名称,并用冒号“:”分隔。如要将“课程信息”表的“名称”字段修改为“课程名称”,则应在“设计网格”中“字段”行显示“名称”之前加上“课程名称:”(注意这里的冒号应该是在英文状态下输入)。第71页/共121页使用表达式
29、使用表达式 在“设计网格”的“字段”行中可以使用表达式。如要将查询结果中学生的成绩加上100,可在“字段”行中输入“成绩+100”。Access自动将其规范化为“表达式1:成绩+100”,冒号之前的为该字段在查询结果中的输出名称。第72页/共121页使用表达式使用表达式第73页/共121页改变字段顺序改变字段顺序 默认情况下,查询结果中各个字段按照“设计网格”中的先后顺序输出。可在“设计网格”中调整各个字段的顺序.第74页/共121页删除选择字段删除选择字段 从“设计网格”中删除已选字段的操作步骤如下:第75页/共121页设置排序方式设置排序方式 默认情况下,查询不对记录排序,“设计网格”的字
30、段的“排序”行显示为空。根据需要可重新对字段进行排序。第76页/共121页 筛选记录筛选记录 在“设计网格”的“条件”和“或”行中,可设置记录的筛选条件。Access允许省略字符串的双引号,并按相等进行比较。也可使用其他的比较运算符,例如(大于)、=(大于等于)、(不等)。如=60可作为“成绩”字段的条件,从而输出成绩大于等于60的记录。第77页/共121页运行查询运行查询在“查询设计器”中,可使用下列方式运行并观察查询结果:第78页/共121页运行查询运行查询运行查询时,Access在“数据表视图”中显示查询结果。在“数据库窗口”中,可使用下列方式运行查询:第79页/共121页运行查询运行查
31、询第80页/共121页应用举例应用举例设计设计“选课成绩单选课成绩单”查询查询 创建一个“选课成绩单”查询,显示学生的学号、姓名、课程名称和成绩等信息。(光盘:chapter3第3章例.mdb)第81页/共121页 查查 询询 向向 导导 通过查询向导可以很方便地建立所需的查询,Access提供了包括简单查询、交叉表查询、查找重复项查询和查找不匹配项查询等4种查询向导,下面分别介绍其用法。简单查询向导交叉表查询向导 查找重复项查询向导 查找不匹配项查询向导 第82页/共121页简单查询向导简单查询向导“简单查询向导”用于创建基于多个表或查询的简单查询。如果使用多个表作为数据源,“简单查询向导”
32、要求定义表之间的关系。使用下列方法可打开“简单查询向导”:第83页/共121页简单查询向导简单查询向导第84页/共121页简单查询向导简单查询向导第85页/共121页简单查询向导简单查询向导第86页/共121页简单查询向导简单查询向导【例3-1】创建“平均成绩”查询,显示学生的姓名、学号和平均成绩。(光盘:chapter3第3章例.mdb)第87页/共121页交叉表查询向导交叉表查询向导 “交叉表查询向导”只能从一个数据源中检索数据。如果需要从多个表中检索数据,可先创建一个查询,然后使用查询来创建交叉表查询。交叉表查询在“数据表视图”中以固定格式显示数据,一个或多个字段作为行标题,一个字段作为
33、列标题,另外一个字段作为表格数据,并可对数据执行各种统计计算,在本节例题中创建的交叉表查询的“数据表视图”。第88页/共121页交叉表查询向导交叉表查询向导第89页/共121页交叉表查询向导交叉表查询向导【例3-2】使用前面创建的“选课成绩单”查询创建“选课成绩单_交叉表”交叉表查询。(光盘:chapter3第3章例.mdb)第90页/共121页查找重复项查询向导查找重复项查询向导查找重复项查询可在表或查询中检索重复的字段值。使用“查找重复项查询向导”,可以快速创建查找重复项查询。【例3-3】创建一个查找重复项查询,检索“选课记录”表中“学号”和“课程号”的重复值。(光盘:chapter3第3
34、章例.mdb)第91页/共121页查找不匹配项查询向导查找不匹配项查询向导 查找不匹配项查询可以从一个表中检索出与另一个表中不匹配的记录。如从“选课记录”表中查找与“学生信息”表中不匹配的记录,从而查看哪些选课记录没有对应的学生信息。【例3-4】创建查找不匹配项查询,查看哪些选课记录没有对应的学生信息。(光盘:chapter3第3章例.mdb)第92页/共121页查询中的运算符与函数查询中的运算符与函数 在查询中,除了使用单个字段外,还可使用运算符和函数来构造各种表达式。Access提供了下列类型的运算符:算术运算符比较运算符字符串运算符逻辑运算符特殊预算符第93页/共121页查询中的运算符与
35、函数查询中的运算符与函数 算术运算符 比较运算符字符串运算符 逻辑运算符 特殊预算符 运算符的优先级 第94页/共121页算术运算符算术运算符算术运算符用于执行算术运算,由算术运算符构成的表达式称为算术表达式。Access支持的算术运算符如下:+:加法,如成绩+10。-:减法,如成绩-10。*:乘法,如成绩*10。/:除法,如7/2,结果为3.5。第95页/共121页算术运算符算术运算符:整除,整数除法,并取结果的整数部分。如果参与运算的数不是整数,则四舍五入为整数。例如62,结果为3;7.52,结果为4。:乘方,如23表示2的3次方。Mod:求余,要求参与运算的数为整数。如果不是整数,则四舍
36、五入为整数。例如7 Mod 2,结果为1。第96页/共121页比较运算符比较运算符 比较运算符用于比较两个值或表达式的大小关系,比较运算又称为关系运算。比较运算的结果为逻辑值(True或False)或Null。由关系运算符构成的表达式称为关系表达式。Access支持的比较运算符如下:=:相等,如成绩=100。:小于,如成绩:大于,如成绩100。=:小于等于,如成绩=:大于等于,如成绩=60。:不等,如成绩100。第97页/共121页字符串运算符字符串运算符 字符串指用双引号括起来的一串字符,文本数据类型字段也是字符串。Access支持的文本运算符如下:&:字符串连接,将两个字符串连接起来,构成
37、一个字符串,例如文本&123。Like:字符串模式匹配,运算结果为True、False或Null。第98页/共121页字符串运算符字符串运算符字符串模式匹配的格式如下:字符串表达式 Like 模式字符串在模式字符串中可使用下列通配符:?:任意的一个字符,如a?表示以字符a开头的,包含一个字符或两个字符的字符串。*:任意长度的任意字符构成的字符串,如a*表示以字符a开头的所有字符串。:任意的一个数字。第99页/共121页字符串运算符字符串运算符列表:列表中的任意一个字符,如abc*表示以ab或ac开头的任意字符串。!列表:不包含列表中的任何字符,如!bc*表示不以b或c开头的任意字符串。在“列表
38、”和“!列表”中,可使用连字符表示范围,例如ab-m*。第100页/共121页逻辑运算符逻辑运算符 逻辑运算符用于对逻辑值进行运算,运算结果仍为逻辑值或Null。由逻辑运算符构成的表达式称为逻辑表达式。逻辑表达式在查询中常常作为条件出现,逻辑真(True)表示条件成立,逻辑假(False)表示条件不成立。Access常用的逻辑运算符如下:Not:逻辑非(取反),Not True为False,Not False为True。第101页/共121页逻辑运算符逻辑运算符And:逻辑与,两个值都为True时,结果才为True。只要有一个值为False,则结果为False。例如,下面的条件表示姓张,而且成
39、绩在60分以上:姓名 Like 张*And 成绩=60。Or:逻辑或,两个值都为False时,结果才为Flase。只要有一个值为True,则结果为True。例如,下面的条件表示姓张,或者成绩在60分以上:姓名 Like 张*Or 成绩=60第102页/共121页特殊预算符特殊预算符 除了一些常用的运算符外,Access还提供了一些特殊预算符,如BetweenAnd、In和Is Null等,下面分别讲解其用法。BetweenAndInIs Null第103页/共121页BetweenAnd BetweenAnd 此预算符表示范围,其格式如下:表达式 Between 值1 And 值2若表达式结果
40、在“值1”和“值2”表示的范围内,则结果为True,否则为False。例如,下面的表达式判断成绩是否在90和100之内(包含90和100):成绩 Between 90 And 100第104页/共121页In In 此预算符用于判断表达式结果是否等于列表中的某个值,其格式如下:表达式 In(值1,值2,值3,)若表达式结果等于列表中的任意一个值,则结果为True,否则为False。例如,下面的表达式判断姓名是否为“张三”、“李四”或“王五”:姓名 In(张三,李四,王五)第105页/共121页Is Null Is Null 此预算符用于判断表达式结果是否为Null,结果为True或False。
41、例如,下面的表达式判断姓名字段是否为空值:姓名 Is Null第106页/共121页 运算符的优先级运算符的优先级 不同的运算符,其运算的先后顺序也有一定规定。按类别确定的运算优先顺序()算术运算符字符串连接比较运算符逻辑运算符算术运算符的优先顺序乘方取负乘法/除法整除求余加法/减法第107页/共121页 运算符的优先级运算符的优先级 优先级相同的按照从左到右的顺序依次计算。所有比较运算符的优先顺序相同,同时出现时按照从左到右的顺序依次计算。逻辑运算符的优先顺序NotAndOr第108页/共121页高高 级级 查查 询询高级查询是查询器的高级使用,主要包括删除查询、参数查询、追加查询和SQL联
42、合查询,下面将详细介绍创建这些查询器的方法。创建删除查询 创建参数查询 创建追加查询 创建SQL联合查询 第109页/共121页创建删除查询创建删除查询删除查询是Access提供的一种操作查询,用于删除符合条件的记录。【例3-5】创建一个查询删除无效的选课记录,无效选课记录指选课记录中的学号在“学生信息”表中没有匹配的记录。(光盘:chapter3第3章例.mdb)第110页/共121页创建参数查询创建参数查询参数查询在执行时提示用户输入参数值,然后根据输入执行查询。【例3-6】创建一个参数查询,查询指定学生的选课信息,输出学生的学号、姓名、课程名称和成绩等信息。(光盘:chapter3第3章
43、例.mdb)第111页/共121页创建追加查询创建追加查询 追加查询可以将查询结果添加到目的表中。【例3-7】创建一个追加查询,利用参数输入学生学号,并与“课程信息”表所有课程的课程号组成选课记录添加到“选课记录”表,选课记录的成绩设置为0。(光盘:chapter3第3章例.mdb)第112页/共121页创建创建SQLSQL联合查询联合查询 联合查询、传递查询和数据定义查询都属于特殊的SQL查询,这些查询只能在SQL视图中进行设计。【例3-8】创建一个SQL联合查询,将“学生信息”和“教师信息”表中的数据合并到一起。(光盘:chapter3第3章例.mdb)第113页/共121页 上上 机机
44、练练 习习 本练习使用“上机练习”数据库(光盘:chapter3上机练习.mdb)中的学生信息、课程信息和选课记录查询学生选择的课程和课程平均成绩。第114页/共121页“学生选课学生选课”信息查询信息查询 “学生选课”信息查询根据输入的学号查询该学生选择的课程清单。第115页/共121页 创建创建“课程平均成绩课程平均成绩”查询查询 创建“课程平均成绩”查询。第116页/共121页习习 题题 使用本书配套光盘提供的数据库(光盘:chapter3第3章习题.mdb)完成下面的练习。(1)设计一个“重复订单”查询,检索“订单”表中“订户号”、“期刊号”、“发行员编号”、“起订期”和“止订期”等字
45、段值都相同的记录。(2)设计一个“订户期刊”查询,检索每个用户订阅的期刊的名称和订阅份数。第117页/共121页习习 题题第118页/共121页习习 题题(3)设计一个“更新期刊单价”查询,修改期刊单价,要求使用查询参数输入期刊名称和价格。(4)设计一个“删除订单”查询,删除订阅份数为“0”的订单。(5)设计一个“邮局发行员”查询,运行查询时,输入邮局名称的前几个字符,即可检索已输入字符开头的邮局的发行员信息。(6)设计一个“追加邮递员”查询,将编号为偶数的发行员添加到“邮递员”表中。(7)设计一个“邮局员工”联合查询,将“发行员”和“邮递员”记录合并。第119页/共121页习习 题题第120页/共121页感谢您的观看!第121页/共121页