第三章关系数据库标准语言SQL.ppt
文本预览下载声明
An Introduction to Database System 3.4 数据查询 3.4.1 单表查询 3.4.2 连接查询 3.4.3 嵌套查询 3.4.4 集合查询 3.4.5 Select语句的一般形式 3.4.2 连接查询 连接查询:同时涉及多个表的查询 连接条件或连接谓词:用来连接两个表的条件 一般格式: [表名1.]列名1 比较运算符 [表名2.]列名2 [表名1.]列名1 BETWEEN [表名2.]列名2 AND [表名2.]列名3 连接字段:连接谓词中的列名称 连接条件中的各连接字段类型必须是可比的,但名字不必是相同的 连接查询(续) 一、等值与非等值连接查询 二、自身连接 三、外连接 四、复合条件连接 一、等值与非等值连接查询 等值连接:连接运算符为= [例33] 查询每个学生及其选修课程的情况 SELECT Student.*,SC.* FROM Student,SC WHERE Student.Sno = SC.Sno; 等值与非等值连接查询(续) 等值与非等值连接查询(续) 自然连接: [例34] 对[例33]用自然连接完成。 SELECT Student.Sno,Sname,Ssex,Sage,Sdept,Cno,Grade FROM Student,SC WHERE Student.Sno = SC.Sno; 连接查询(续) 一、等值与非等值连接查询 二、自身连接 三、外连接 四、复合条件连接 二、自身连接 自身连接:一个表与其自己进行连接 需要给表起别名以示区别 由于所有属性名都是同名属性,因此必须使用别名前缀 [例35]查询每一门课的间接先修课(即先修课的先修课) SELECT FIRST.Cno,SECOND.Cpno FROM Course FIRST,Course SECOND WHERE FIRST.Cpno = SECOND.Cno; 自身连接(续) FIRST表(Course表) 自身连接(续) SECOND表(Course表) 自身连接(续) 连接查询(续) 一、等值与非等值连接查询 二、自身连接 三、外连接(不要求) 四、复合条件连接 三、外连接(不要求) 外连接与普通连接的区别 普通连接操作只输出满足连接条件的元组 外连接操作以指定表为连接主体,将主体表中不满足连接条件的元组一并输出 [例 36] 改写[例33] SELECT Student.Sno,Sname,Ssex,Sage,Sdept,Cno,Grade FROM Student LEFT OUT JOIN SC ON (Student.Sno=SC.Sno); 外连接(续) 外连接(续) 左外连接 列出左边关系(如本例Student)中所有的元组 右外连接 列出右边关系中所有的元组 连接查询(续) 一、等值与非等值连接查询 二、自身连接 三、外连接 四、复合条件连接 四、复合条件连接 复合条件连接:WHERE子句中含多个连接条件 [例37]查询选修2号课程且成绩在90分以上的所有学生 SELECT Student.Sno, Sname FROM Student, SC WHERE Student.Sno = SC.Sno AND /* 连接谓词*/ SC.Cno= ‘2’ AND SC.Grade 90; /* 其他限定条件 */ 复合条件连接(续) [例38]查询每个学生的学号、姓名、选修的课程名及成绩 SELECT Student.Sno,Sname,Cname,Grade FROM Student,SC,Course /*多表连接*/ WHERE Student.Sno = SC.Sno and SC.Cno = Course.Cno; ? 3.4 数据查询 3.4.1 单表查询 3.4.2 连接查询 3.4.3 嵌套查询 3.4.4 集合查询 3.4.5 Select语句的一般形式 嵌套查询(续) 嵌套查询概述 一个SELECT-FROM-WHERE语句称为一个查询块 将一个查询块嵌套在另一个查询块的WHERE子句或HAVING短语的条件中的查询称为嵌套查询 嵌套查询 举例 SE
显示全部