欢迎来到天天文库
浏览记录
ID:55726287
大小:424.50 KB
页数:99页
时间:2020-06-02
《数据库原理课件第4版 第3章(2)DataBase.ppt》由会员上传分享,免费在线阅读,更多相关内容在教育资源-天天文库。
1、中国人民大学信息学院计算机系数据库系统概论AnIntroductiontoDatabaseSystem第三章关系数据库标准语言SQL(续1)AnIntroductiontoDatabaseSystem3.4查询概述3.4.1单表查询3.4.2连接查询3.4.3嵌套查询3.4.4集合查询3.4.5SELECT语句的一般格式AnIntroductiontoDatabaseSystem3.4.2连接查询同时涉及多个表的查询称为连接查询用来连接两个表的条件称为连接条件或连接谓词一般格式:[<表名1>.]<列名1><比较运算符
2、>[<表名2>.]<列名2>比较运算符:=、>、<、>=、<=、!=[<表名1>.]<列名1>BETWEEN[<表名2>.]<列名2>AND[<表名2>.]<列名3>AnIntroductiontoDatabaseSystem连接查询(续)连接字段连接谓词中的列名称为连接字段连接条件中的各连接字段类型必须是可比的,但不必是相同的AnIntroductiontoDatabaseSystem连接操作的执行过程嵌套循环法(NESTED-LOOP)首先在表1中找到第一个元组,然后从头开始扫描表2,逐一查找满足连接件的元组,找
3、到后就将表1中的第一个元组与该元组拼接起来,形成结果表中一个元组。表2全部查找完后,再找表1中第二个元组,然后再从头开始扫描表2,逐一查找满足连接条件的元组,找到后就将表1中的第二个元组与该元组拼接起来,形成结果表中一个元组。重复上述操作,直到表1中的全部元组都处理完毕AnIntroductiontoDatabaseSystem排序合并法(SORT-MERGE)常用于=连接首先按连接属性对表1和表2排序对表1的第一个元组,从头开始扫描表2,顺序查找满足连接条件的元组,找到后就将表1中的第一个元组与该元组拼接起来,形成
4、结果表中一个元组。当遇到表2中第一条大于表1连接字段值的元组时,对表2的查询不再继续AnIntroductiontoDatabaseSystem排序合并法找到表1的第二条元组,然后从刚才的中断点处继续顺序扫描表2,查找满足连接条件的元组,找到后就将表1中的第一个元组与该元组拼接起来,形成结果表中一个元组。直接遇到表2中大于表1连接字段值的元组时,对表2的查询不再继续重复上述操作,直到表1或表2中的全部元组都处理完毕为止AnIntroductiontoDatabaseSystem索引连接(INDEX-JOIN)对表2按
5、连接字段建立索引对表1中的每个元组,依次根据其连接字段值查询表2的索引,从中找到满足条件的元组,找到后就将表1中的第一个元组与该元组拼接起来,形成结果表中一个元组AnIntroductiontoDatabaseSystem连接查询(续)SQL中连接查询的主要类型广义笛卡尔积等值连接(含自然连接)非等值连接查询自身连接查询外连接查询复合条件连接查询AnIntroductiontoDatabaseSystem一、广义笛卡尔积不带连接谓词的连接很少使用例:SELECTStudent.*,SC.*FROMStudent,SC
6、AnIntroductiontoDatabaseSystem二、等值与非等值连接查询等值连接、自然连接、非等值连接[例32]查询每个学生及其选修课程的情况。SELECTStudent.*,SC.*FROMStudent,SCWHEREStudent.Sno=SC.Sno;AnIntroductiontoDatabaseSystem等值连接连接运算符为=的连接操作[<表名1>.]<列名1>=[<表名2>.]<列名2>任何子句中引用表1和表2中同名属性时,都必须加表名前缀。引用唯一属性名时可以加也可以省略表名前缀。AnI
7、ntroductiontoDatabaseSystem等值连接假设Student表、SC表分别有下列数据:Student表SnoSnameSsexSageSdept95001李勇男20CS95002刘晨女19IS95003王敏女18MA95004张立男19ISAnIntroductiontoDatabaseSystem等值连接SC表SnoCnoGrade9500119295001285950019500295002323889080AnIntroductiontoDatabaseSystem等值连接结果表Studen
8、t.SnoSnameSsexSageSdeptSC.SnoCnoGrade95001李勇男20CS9500119295001李勇男20CS9500128595001李勇男20CS9500138895002刘晨女19IS9500229095002刘晨女19IS95002380AnIntroductiontoDatabaseSystem自然连接等值
此文档下载收益归作者所有