sqlserver等值连接非等值连接.ppt

上传人:za****8 文档编号:14448338 上传时间:2020-07-21 格式:PPT 页数:38 大小:578KB
返回 下载 相关 举报
sqlserver等值连接非等值连接.ppt_第1页
第1页 / 共38页
sqlserver等值连接非等值连接.ppt_第2页
第2页 / 共38页
sqlserver等值连接非等值连接.ppt_第3页
第3页 / 共38页
点击查看更多>>
资源描述
An Introduction to Database System,连接操作的执行过程,嵌套循环法(NESTED-LOOP) 首先在表1中找到第一个元组,然后从头开始扫描表2,逐一查找满足连接件的元组,找到后就将表1中的第一个元组与该元组拼接起来,形成结果表中一个元组。 表2全部查找完后,再找表1中第二个元组,然后再从头开始扫描表2,逐一查找满足连接条件的元组,找到后就将表1中的第二个元组与该元组拼接起来,形成结果表中一个元组。 重复上述操作,直到表1中的全部元组都处理完毕,An Introduction to Database System,排序合并法(SORT-MERGE),常用于=连接 首先按连接属性对表1和表2排序 对表1的第一个元组,从头开始扫描表2,顺序查找满足连接条件的元组,找到后就将表1中的第一个元组与该元组拼接起来,形成结果表中一个元组。当遇到表2中第一条大于表1连接字段值的元组时,对表2的查询不再继续,An Introduction to Database System,排序合并法,找到表1的第二条元组,然后从刚才的中断点处继续顺序扫描表2,查找满足连接条件的元组,找到后就将表1中的第二个元组与该元组拼接起来,形成结果表中一个元组。直接遇到表2中大于表1连接字段值的元组时,对表2的查询不再继续 重复上述操作,直到表1或表2中的全部元组都处理完毕为止,An Introduction to Database System,连接查询(续),一、等值与非等值连接查询 二、自身连接 三、外连接 四、复合条件连接,An Introduction to Database System,一、等值与非等值连接查询,等值连接:连接运算符为= 例33 查询每个学生及其选修课程的情况 SELECT Student.*,SC.* FROM Student,SC WHERE Student.Sno = SC.Sno;,An Introduction to Database System,等值与非等值连接查询(续),查询结果:,An Introduction to Database System,等值与非等值连接查询(续),自然连接: 例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查询每一门课的间接先修课(即先修课的先修课) 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 Database 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 System,外连接(续),执行结果:,An Introduction to Database System,四、复合条件连接,复合条件连接:WHERE子句中含多个连接条件 例37查询选修2号课程且成绩在90分以上的所有学生 SELECT Student.Sno, Sname FROM Student, SC WHERE Student.Sno = SC.Sno AND /* 连接谓词*/ SC.Cno= 2 AND SC.Grade 90; /* 其他限定条件 */,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 System,id name |id score | 1 lee |1 90 | 2 zhang |2 100 | 4 wang |3 70 | 一、外连接 1.概念:包括左向外联接、右向外联接或完整外部联接 2.左连接:left join 或 left 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 on table1.id=table2.id 1 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 Student 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,带有比较运算符的子查询(续),例:假设一个学生只可能在一个系学习,并且必须属于一个系,则在例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 System,带有比较运算符的子查询(续),例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)或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 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,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子句返回假值 若内层查询结果为空,则外层的WHERE子句返回真值,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 Sname FROM Student, SC WHERE 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,下课了。,休息一会儿。,追 求,
展开阅读全文
相关资源
正为您匹配相似的精品文档
相关搜索

最新文档


当前位置:首页 > 图纸专区 > 课件教案


copyright@ 2023-2025  zhuangpeitu.com 装配图网版权所有   联系电话:18123376007

备案号:ICP2024067431-1 川公网安备51140202000466号


本站为文档C2C交易模式,即用户上传的文档直接被用户下载,本站只是中间服务平台,本站所有文档下载所得的收益归上传人(含作者)所有。装配图网仅提供信息存储空间,仅对用户上传内容的表现方式做保护处理,对上载内容本身不做任何修改或编辑。若文档所含内容侵犯了您的版权或隐私,请立即通知装配图网,我们立即给予删除!