《sqlserver等值连接非等值连接.ppt》由会员分享,可在线阅读,更多相关《sqlserver等值连接非等值连接.ppt(38页珍藏版)》请在三一办公上搜索。
1、An Introduction to Database System,连接操作的执行过程,嵌套循环法(NESTED-LOOP)首先在表1中找到第一个元组,然后从头开始扫描表2,逐一查找满足连接件的元组,找到后就将表1中的第一个元组与该元组拼接起来,形成结果表中一个元组。表2全部查找完后,再找表1中第二个元组,然后再从头开始扫描表2,逐一查找满足连接条件的元组,找到后就将表1中的第二个元组与该元组拼接起来,形成结果表中一个元组。重复上述操作,直到表1中的全部元组都处理完毕,An Introduction to Database System,排序合并法(SORT-MERGE),常用于=连接首先按
2、连接属性对表1和表2排序对表1的第一个元组,从头开始扫描表2,顺序查找满足连接条件的元组,找到后就将表1中的第一个元组与该元组拼接起来,形成结果表中一个元组。当遇到表2中第一条大于表1连接字段值的元组时,对表2的查询不再继续,An Introduction to Database System,排序合并法,找到表1的第二条元组,然后从刚才的中断点处继续顺序扫描表2,查找满足连接条件的元组,找到后就将表1中的第二个元组与该元组拼接起来,形成结果表中一个元组。直接遇到表2中大于表1连接字段值的元组时,对表2的查询不再继续重复上述操作,直到表1或表2中的全部元组都处理完毕为止,An Introduc
3、tion to Database System,连接查询(续),一、等值与非等值连接查询 二、自身连接三、外连接四、复合条件连接,An Introduction to Database System,一、等值与非等值连接查询,等值连接:连接运算符为=例33 查询每个学生及其选修课程的情况 SELECT Student.*,SC.*FROM Student,SCWHERE Student.Sno=SC.Sno;,An Introduction to Database System,等值与非等值连接查询(续),查询结果:,An Introduction to Database System,等值与
4、非等值连接查询(续),自然连接:例34 对例33用自然连接完成。SELECT Student.Sno,Sname,Ssex,Sage,Sdept,Cno,Grade FROM Student,SC WHERE Student.Sno=SC.Sno;,An Introduction to Database System,连接查询(续),一、等值与非等值连接查询 二、自身连接三、外连接四、复合条件连接,An Introduction to Database System,二、自身连接,自身连接:一个表与其自己进行连接需要给表起别名以示区别由于所有属性名都是同名属性,因此必须使用别名前缀例35查询每
5、一门课的间接先修课(即先修课的先修课)SELECT FIRST.Cno,SECOND.Cpno FROM Course FIRST,Course SECOND WHERE FIRST.Cpno=SECOND.Cno;,An Introduction to Database System,自身连接(续),FIRST表(Course表),An Introduction to Database System,自身连接(续),SECOND表(Course表),An Introduction to Database System,自身连接(续),查询结果:,An Introduction to Data
6、base System,连接查询(续),一、等值与非等值连接查询 二、自身连接三、外连接四、复合条件连接,An Introduction to Database System,三、外连接,外连接与普通连接的区别普通连接操作只输出满足连接条件的元组外连接操作以指定表为连接主体,将主体表中不满足连接条件的元组一并输出例 36 改写例33 SELECT Student.Sno,Sname,Ssex,Sage,Sdept,Cno,Grade FROM Student LEFT OUT JOIN SC ON(Student.Sno=SC.Sno);,An Introduction to Database
7、 System,外连接(续),执行结果:,An Introduction to Database System,四、复合条件连接,复合条件连接:WHERE子句中含多个连接条件例37查询选修2号课程且成绩在90分以上的所有学生SELECT Student.Sno,SnameFROM Student,SCWHERE Student.Sno=SC.Sno AND/*连接谓词*/SC.Cno=2 AND SC.Grade 90;/*其他限定条件*/,An Introduction to Database System,嵌套查询(续),SELECT Sname/*外层查询/父查询*/FROM Stude
8、nt WHERE Sno IN(SELECT Sno/*内层查询/子查询*/FROM SC WHERE Cno=2);,An Introduction to Database System,嵌套查询(续),子查询的限制不能使用ORDER BY子句层层嵌套方式反映了 SQL语言的结构化有些嵌套查询可以用连接运算替代,An Introduction to Database System,id name|id score|1 lee|1 90|2 zhang|2 100|4 wang|3 70|一、外连接 1.概念:包括左向外联接、右向外联接或完整外部联接 2.左连接:left join 或 lef
9、t outer join select*from table1 left join table2 on table1.id=table2.id 1 lee 1 90 2 zhang 2 100 4 wang NULL NULL 右连接:right join 或 right outer join select*from table1 right join table2 on table1.id=table2.id 1 lee 1 90 2 zhang 2 100 NULL NULL 3 70.内连接:join 或 inner join select*from table1 join table2
10、 on table1.id=table2.id1 lee 1 90 2 zhang 2 100,An Introduction to Database System,3.4.3 嵌套查询,一、带有IN谓词的子查询 二、带有比较运算符的子查询 三、带有ANY(SOME)或ALL谓词的子查询 四、带有EXISTS谓词的子查询,An Introduction to Database System,带有IN谓词的子查询(续),将第一步查询嵌入到第二步查询的条件中 SELECT Sno,Sname,Sdept FROM Student WHERE Sdept IN(SELECT Sdept FROM S
11、tudent WHERE Sname=刘晨);此查询为不相关子查询。,An Introduction to Database System,3.4.3 嵌套查询,一、带有IN谓词的子查询 二、带有比较运算符的子查询三、带有ANY(SOME)或ALL谓词的子查询四、带有EXISTS谓词的子查询,An Introduction to Database System,二、带有比较运算符的子查询,当能确切知道内层查询返回单值时,可用比较运算符(,=,)。,An Introduction to Database System,带有比较运算符的子查询(续),例:假设一个学生只可能在一个系学习,并且必须属于
12、一个系,则在例39可以用=代替IN:SELECT Sno,Sname,Sdept FROM Student WHERE Sdept=(SELECT Sdept FROM Student WHERE Sname=刘晨);,An Introduction to Database System,带有比较运算符的子查询(续),子查询一定要跟在比较符之后 错误的例子:SELECT Sno,Sname,Sdept FROM Student WHERE(SELECT Sdept FROM Student WHERE Sname=刘晨)=Sdept;,An Introduction to Database S
13、ystem,带有比较运算符的子查询(续),例41找出每个学生超过他选修课程平均成绩的课程号。SELECT Sno,Cno FROM SC x WHERE Grade=(SELECT AVG(Grade)FROM SC y WHERE y.Sno=x.Sno);,相关子查询,An Introduction to Database System,3.4.3 嵌套查询,一、带有IN谓词的子查询 二、带有比较运算符的子查询 三、带有ANY(SOME)或ALL谓词的子查询 四、带有EXISTS谓词的子查询,An Introduction to Database System,三、带有ANY(SOME)或
14、ALL谓词的子查询,谓词语义ANY:任意一个值ALL:所有值,An Introduction to Database System,带有ANY(SOME)或ALL谓词的子查询(续),例42 查询其他系中比计算机科学某一学生年龄小的学生姓名和年龄 SELECT Sname,Sage FROM Student WHERE Sage CS;/*父查询块中的条件*/,An Introduction to Database System,带有ANY(SOME)或ALL谓词的子查询(续),用聚集函数实现例42 SELECT Sname,Sage FROM Student WHERE Sage CS;,An
15、 Introduction to Database System,带有ANY(SOME)或ALL谓词的子查询(续),例43 查询其他系中比计算机科学系所有学生年龄都小的学生姓名及年龄。方法一:用ALL谓词 SELECT Sname,Sage FROM Student WHERE Sage CS;,An Introduction to Database System,带有ANY(SOME)或ALL谓词的子查询(续),方法二:用聚集函数 SELECT Sname,Sage FROM Student WHERE Sage CS;,An Introduction to Database System,
16、3.4.3 嵌套查询,一、带有IN谓词的子查询 二、带有比较运算符的子查询 三、带有ANY(SOME)或ALL谓词的子查询 四、带有EXISTS谓词的子查询,An Introduction to Database System,带有EXISTS谓词的子查询(续),1.EXISTS谓词存在量词 带有EXISTS谓词的子查询不返回任何数据,只产生逻辑真值“true”或逻辑假值“false”。若内层查询结果非空,则外层的WHERE子句返回真值若内层查询结果为空,则外层的WHERE子句返回假值2.NOT EXISTS谓词若内层查询结果非空,则外层的WHERE子句返回假值若内层查询结果为空,则外层的WH
17、ERE子句返回真值,An Introduction to Database System,带有EXISTS谓词的子查询(续),用嵌套查询 SELECT Sname FROM Student WHERE EXISTS(SELECT*FROM SC WHERE Sno=Student.Sno AND Cno=1);,An Introduction to Database System,带有EXISTS谓词的子查询(续),用连接运算SELECT SnameFROM Student,SCWHERE Student.Sno=SC.Sno AND SC.Cno=1;,An Introduction to Database System,3.4.5 SELECT语句的一般格式,SELECT ALL|DISTINCT 别名,别名 FROM 别名,别名 WHERE GROUP BY HAVING ORDER BY ASC|DESC,An Introduction to Database System,下课了。,休息一会儿。,追求,