sqlserver等值连接非等值连接

上传人:hs****ma 文档编号:568303462 上传时间:2024-07-24 格式:PPT 页数:38 大小:578.19KB
返回 下载 相关 举报
sqlserver等值连接非等值连接_第1页
第1页 / 共38页
sqlserver等值连接非等值连接_第2页
第2页 / 共38页
sqlserver等值连接非等值连接_第3页
第3页 / 共38页
sqlserver等值连接非等值连接_第4页
第4页 / 共38页
sqlserver等值连接非等值连接_第5页
第5页 / 共38页
点击查看更多>>
资源描述

《sqlserver等值连接非等值连接》由会员分享,可在线阅读,更多相关《sqlserver等值连接非等值连接(38页珍藏版)》请在金锄头文库上搜索。

1、连接操作的执行过程连接操作的执行过程v嵌套循环法(NESTED-LOOP)首先在表1中找到第一个元组,然后从头开始扫描表2,逐一查找满足连接件的元组,找到后就将表1中的第一个元组与该元组拼接起来,形成结果表中一个元组。表2全部查找完后,再找表1中第二个元组,然后再从头开始扫描表2,逐一查找满足连接条件的元组,找到后就将表1中的第二个元组与该元组拼接起来,形成结果表中一个元组。重复上述操作,直到表1中的全部元组都处理完毕 An Introduction to Database System排序合并法排序合并法(SORT-MERGE)常用于=连接首先按连接属性对表1和表2排序对表1的第一个元组,从

2、头开始扫描表2,顺序查找满足连接条件的元组,找到后就将表1中的第一个元组与该元组拼接起来,形成结果表中一个元组。当遇到表2中第一条大于表1连接字段值的元组时,对表2的查询不再继续An Introduction to Database System排序合并法排序合并法找到表1的第二条元组,然后从刚才的中断点处继续顺序扫描表2,查找满足连接条件的元组,找到后就将表1中的第二个元组与该元组拼接起来,形成结果表中一个元组。直接遇到表2中大于表1连接字段值的元组时,对表2的查询不再继续重复上述操作,直到表1或表2中的全部元组都处理完毕为止 An Introduction to Database Syst

3、em连接查询(续)连接查询(续)一、等值与非等值连接查询 二、自身连接三、外连接四、复合条件连接An Introduction to Database System一、等值与非等值连接查询一、等值与非等值连接查询 v等值连接:连接运算符为=例33 查询每个学生及其选修课程的情况 SELECT Student.*,SC.* FROM Student,SCWHERE Student.Sno = SC.Sno;An Introduction to Database System等值与非等值连接查询(续)等值与非等值连接查询(续)Student.SnoSnameSsexSageSdeptSC.SnoC

4、noGrade200215121李勇男20CS200215121192200215121李勇男20CS200215121285200215121李勇男20CS200215121388200215122刘晨女19CS200215122290200215122刘晨女19CS200215122380查询结果:查询结果:An Introduction to Database System等值与非等值连接查询(续)等值与非等值连接查询(续)v自然连接:例34 对例33用自然连接完成。 SELECT Student.Sno,Sname,Ssex,Sage,Sdept,Cno,Grade FROM Stud

5、ent,SC WHERE Student.Sno = SC.Sno;An Introduction to Database System连接查询(续)连接查询(续)一、等值与非等值连接查询 二、自身连接三、外连接四、复合条件连接An Introduction to Database System二、自身连接二、自身连接 v自身连接:一个表与其自己进行连接v需要给表起别名以示区别v由于所有属性名都是同名属性,因此必须使用别名前缀例35查询每一门课的间接先修课(即先修课的先修课) SELECT FIRST.Cno,SECOND.Cpno FROM Course FIRST,Course SECON

6、D WHERE FIRST.Cpno = SECOND.Cno;An Introduction to Database System自身连接(续)自身连接(续) FIRST表(Course表) Cno CnameCpnoCcredit 1数据库数据库 5 4 2数学数学 2 3信息系统信息系统 1 4 4操作系统操作系统 6 3 5数据结构数据结构 7 4 6数据处理数据处理 2 7PASCAL语言语言 6 4An Introduction to Database System自身连接(续)自身连接(续)Cno CnameCpnoCcredit 1数据库数据库 5 4 2数学数学 2 3信息系

7、统信息系统 1 4 4操作系统操作系统 6 3 5数据结构数据结构 7 4 6数据处理数据处理 2 7PASCAL语言语言 6 4 SECOND表(Course表) An Introduction to Database System自身连接(续)自身连接(续)查询结果:CnoPcno173556An Introduction to Database System连接查询(续)连接查询(续)一、等值与非等值连接查询 二、自身连接三、外连接四、复合条件连接An Introduction to Database System三、外连接三、外连接v外连接与普通连接的区别普通连接操作只输出满足连接条件

8、的元组外连接操作以指定表为连接主体,将主体表中不满足连接条件的元组一并输出例 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 System外连接(续外连接(续) 执行结果:执行结果: Student.SnoSnameSsexSageSdeptCnoGrade200215121李勇男20CS192200215121李勇男20CS285200215121李勇男20

9、CS388200215122刘晨女19CS290200215122刘晨女19CS380200215123王敏女18MANULLNULL200215125张立男19ISNULLNULLAn Introduction to Database System四、复合条件连接四、复合条件连接v复合条件连接:WHERE子句中含多个连接条件例37查询选修2号课程且成绩在90分以上的所有学生SELECT Student.Sno, SnameFROM Student, SCWHERE Student.Sno = SC.Sno AND /* 连接谓词*/ SC.Cno= 2 AND SC.Grade 90; /*

10、 其他限定条件 */An Introduction to Database System嵌套查询嵌套查询(续续) SELECT Sname /*外层查询/父查询*/ FROM Student WHERE Sno IN (SELECT Sno /*内层查询/子查询*/ FROM SC WHERE Cno= 2 );An Introduction to Database System嵌套查询嵌套查询(续续)子查询的限制不能使用ORDER BY子句层层嵌套方式反映了 SQL语言的结构化有些嵌套查询可以用连接运算替代An Introduction to Database Systemvid name

11、|id score | 1 lee |1 90 | 2 zhang |2 100 | 4 wang |3 70 | v一、外连接 1.概念:包括左向外联接、右向外联接或完整外部联接 2.左连接:left join 或 left outer join vselect * from table1 left join table2 on table1.id=table2.id v1 lee 1 90 2 zhang 2 100 4 wang NULL NULL v右连接:right join 或 right outer join select * from table1 right join tab

12、le2 on table1.id=table2.id 1 lee 1 90 2 zhang 2 100 NULL NULL 3 70v.内连接:join 或 inner join vselect * from table1 join table2 on table1.id=table2.idv1 lee 1 90 2 zhang 2 100 An Introduction to Database System3.4.3 嵌套查询嵌套查询 一、带有IN谓词的子查询 二、 带有比较运算符的子查询 三、 带有ANY(SOME)或ALL谓词的子查询 四、 带有EXISTS谓词的子查询An Introd

13、uction to Database System带有带有IN谓词的子查询(续)谓词的子查询(续)将第一步查询嵌入到第二步查询的条件中 SELECT Sno,Sname,Sdept FROM Student WHERE Sdept IN (SELECT Sdept FROM Student WHERE Sname= 刘晨 ); 此查询为不相关子查询。An Introduction to Database System3.4.3 嵌套查询嵌套查询 一、带有IN谓词的子查询 二、 带有比较运算符的子查询三、 带有ANY(SOME)或ALL谓词的子查询四、 带有EXISTS谓词的子查询An Intr

14、oduction to Database System二、带有比较运算符的子查询二、带有比较运算符的子查询v 当能确切知道内层查询返回单值时,可用比较运算符(,=,=,!=或)。An Introduction to Database System带有比较运算符的子查询(续)带有比较运算符的子查询(续)例:假设一个学生只可能在一个系学习,并且必须属于一个系,则在例39可以用 = 代替IN : SELECT Sno,Sname,Sdept FROM Student WHERE Sdept = (SELECT Sdept FROM Student WHERE Sname= 刘晨);An Introd

15、uction to Database System带有比较运算符的子查询(续)带有比较运算符的子查询(续) 子查询一定要跟在比较符之后 错误错误的例子: SELECT Sno,Sname,Sdept FROM Student WHERE ( SELECT Sdept FROM Student WHERE Sname= 刘晨 ) = Sdept;An Introduction to Database System带有比较运算符的子查询(续)带有比较运算符的子查询(续)例41找出每个学生超过他选修课程平均成绩的课程号。 SELECT Sno, Cno FROM SC x WHERE Grade =

16、(SELECT AVG(Grade) FROM SC y WHERE y.Sno=x.Sno);相关子查询相关子查询 An Introduction to Database System3.4.3 嵌套查询嵌套查询 一、带有IN谓词的子查询 二、 带有比较运算符的子查询 三、 带有ANY(SOME)或ALL谓词的子查询 四、 带有EXISTS谓词的子查询An Introduction to Database System三、带有三、带有ANY(SOME)或)或ALL谓词的子查询谓词的子查询 谓词语义ANY:任意一个值ALL:所有值An Introduction to Database Syst

17、em带有带有ANY(SOME)或)或ALL谓词的子查询谓词的子查询 (续)(续)例42 查询其他系中比计算机科学某一学生年龄小的学生姓名和年龄 SELECT Sname,Sage FROM Student WHERE Sage ANY (SELECT Sage FROM Student WHERE Sdept= CS ) AND Sdept CS ; /*父查询块中的条件 */An Introduction to Database System带有带有ANY(SOME)或)或ALL谓词的子查询谓词的子查询 (续)(续)用聚集函数实现例42 SELECT Sname,Sage FROM Stud

18、ent WHERE Sage (SELECT MAX(Sage) FROM Student WHERE Sdept= CS ) AND Sdept CS ;An Introduction to Database System带有带有ANY(SOME)或)或ALL谓词的子查询谓词的子查询 (续)(续)例43 查询其他系中比计算机科学系所有学生年龄都小的学生姓名及年龄。方法一:用ALL谓词 SELECT Sname,Sage FROM Student WHERE Sage ALL (SELECT Sage FROM Student WHERE Sdept= CS ) AND Sdept CS ;A

19、n Introduction to Database System带有带有ANY(SOME)或)或ALL谓词的子查询谓词的子查询 (续)(续) 方法二:用聚集函数 SELECT Sname,Sage FROM Student WHERE Sage (SELECT MIN(Sage) FROM Student WHERE Sdept= CS ) AND Sdept CS ;An Introduction to Database System3.4.3 嵌套查询嵌套查询 一、带有IN谓词的子查询 二、 带有比较运算符的子查询 三、 带有ANY(SOME)或ALL谓词的子查询 四、 带有EXISTS

20、谓词的子查询An Introduction to Database System带有带有EXISTS谓词的子查询谓词的子查询(续)续)v1. EXISTS谓词n存在量词 n带有EXISTS谓词的子查询不返回任何数据,只产生逻辑真值“true”或逻辑假值“false”。若内层查询结果非空,则外层的WHERE子句返回真值若内层查询结果为空,则外层的WHERE子句返回假值v2. NOT EXISTS谓词若内层查询结果非空,则外层的WHERE子句返回假值若内层查询结果为空,则外层的WHERE子句返回真值An Introduction to Database System带有带有EXISTS谓词的子查询

21、谓词的子查询(续)续)n用嵌套查询 SELECT Sname FROM Student WHERE EXISTS (SELECT * FROM SC WHERE Sno=Student.Sno AND Cno= 1 ); An Introduction to Database System带有带有EXISTS谓词的子查询谓词的子查询(续)续)n用连接运算SELECT SnameFROM Student, SCWHERE Student.Sno=SC.Sno AND SC.Cno= 1;An Introduction to Database System3.4.5 SELECT语句的一般格式语句的一般格式 SELECT ALL|DISTINCT 别名 , 别名 FROM 别名 , 别名 WHERE GROUP BY HAVING ORDER BY ASC|DESC An Introduction to Database System 下课了。下课了。休息一会儿。休息一会儿。An Introduction to Database System

展开阅读全文
相关资源
正为您匹配相似的精品文档
相关搜索

最新文档


当前位置:首页 > 资格认证/考试 > 自考

电脑版 |金锄头文库版权所有
经营许可证:蜀ICP备13022795号 | 川公网安备 51140202000112号