网站大量收购独家精品文档,联系QQ:2885784924

2022年关系数据库标准语言SQL(1).ppt

  1. 1、本文档共35页,可阅读全部内容。
  2. 2、原创力文档(book118)网站文档一经付费(服务费),不意味着购买了该文档的版权,仅供个人/单位学习、研究之用,不得用于商业用途,未经授权,严禁复制、发行、汇编、翻译或者网络传播等,侵权必究。
  3. 3、本站所有内容均由合作方或网友上传,本站不对文档的完整性、权威性及其观点立场正确性做任何保证或承诺!文档内容仅供研究参考,付费前请自行鉴别。如您付费,意味着您自己接受本站规则且自行承担风险,本站不退款、不进行额外附加服务;查看《如何避免下载的几个坑》。如果您已付费下载过本站文档,您可以点击 这里二次下载
  4. 4、如文档侵犯商业秘密、侵犯著作权、侵犯人身权等,请点击“版权申诉”(推荐),也可以打举报电话:400-050-0827(电话支持时间:9:00-18:30)。
查看更多

学习目标;3.3查询;连接查询:同时涉及多个表的查询。用来连接两个表的条件称为连接条件或连接谓词。

连接条件的一般格式:

[表名1.]列名1比较运算符[表名2.]列名2

或[表名1.]列名1BETWEEN[表名2.]列名2AND[表名3.]列名3

其中:连接谓词中的列名称为连接字段,连接条件中的各连接字段类型必须是可比的,但不必是相同的。;连接操作的执行过程

嵌套循环法

首先在表1中找到第一个元组,然后从头开始扫描表2,逐一查找满足连接件的元组,找到后就将表1中的第一个元组与该元组拼接起来,形成结果表中一个元组。

表2全部查找完后,再找表1中第二个元组,然后再从头开始扫描表2,逐一查找满足连接条件的元组,找到后就将表1中的第二个元组与该元组拼接起来,形成结果表中一个元组。

重复上述操作,直到表1中的全部元组都处理完毕。

排序合并法

首先按连接属性对表1和表2排序。

对表1的第一个元组,从头开始扫描表2,顺序查找满足连接条件的元组,找到后就将表1中的第一个元组与该元组拼接起来,形成结果表中一个元组。当遇到表2中第一条大于表1连接字段值的元组时,对表2的查询不再继续。;找到表1的第二条元组,然后从刚才的中断点处继续顺序扫描表2,查找满足连接条件的元组,找到后就将表1中的第一个元组与该元组拼接起来,形成结果表中一个元组。直接遇到表2中大于表1连接字段值的元组时,对表2的查询不再继续。

重复上述操作,直到表1或表2中的全部元组都处理完毕为止。

索引连接

对表2按连接字段建立索引。

对表1中的每个元组,依次根据其连接字段值查询表2的索引,从中找到满足条件的元组,找到后就将表1中的第一个元组与该元组拼接起来,形成结果表中一个元组。;SQL中连接查询的主要类型:广义笛卡尔积查询、等值连接(含自然连接)查询、非等值连接查询、自身连接查询、外连接查询、复合条件连接查询。

广义笛卡尔积(很少使用):不带连接谓词的连接。

例:SELECTStudent.*,SC.*FROMStudent,SC;

等值连接:连接运算符??=的连接操作。

格式:[表名1.]列名1=[表名2.]列名2

说明:任何子句中引用表1和表2中同名属性时,都必须加表名前缀。引用唯一属性名时可以加也可以省略表名前缀。;Student;[例32]查询每个学生及其选修课程的情况。

SELECTStudent.*,SC.*FROMStudent,SC

WHEREStudent.Sno=SC.Sno;

结果:

Student.SnoSnameSsexSageSdeptSC.SnoCnoGrade

95001李勇男20 CS 95001192

95001李勇男20 CS 95001285

95001李勇男20 CS 95001388

95002刘晨女19 IS 95002290

95002刘晨女19 IS 95002380;自然连接:等值连接的一种特殊情况,把目标列中重复的属性列去掉。

[例33]对例32用自然连接完成。

SELECTStudent.Sno,Sname,Ssex,Sage,Sdept,Cno,Grade

FROMStudent,SCWHEREStudent.Sno=SC.Sno;

非等值连接查询:连接运算符不是=的连接操作。

自身连接:一个表与其自己进行连接。连接需给表起别名以示区别,由于所有属性名都是同名属性,因此须使用别名前缀。

[例34]查询每一门课的间接先修课(即先修课的先修课)。

SELECTFIRST.Cno,SECOND.Cpno

FROMCourseFIRST,CourseSECOND

WHEREFIRST.Cpno=SECOND.Cno;;;外连接:在普通连接操作中只有满足

文档评论(0)

yjhbester + 关注
实名认证
内容提供者

该用户很懒,什么也没介绍

1亿VIP精品文档

相关文档