- 1、本文档共7页,可阅读全部内容。
- 2、原创力文档(book118)网站文档一经付费(服务费),不意味着购买了该文档的版权,仅供个人/单位学习、研究之用,不得用于商业用途,未经授权,严禁复制、发行、汇编、翻译或者网络传播等,侵权必究。
- 3、本站所有内容均由合作方或网友上传,本站不对文档的完整性、权威性及其观点立场正确性做任何保证或承诺!文档内容仅供研究参考,付费前请自行鉴别。如您付费,意味着您自己接受本站规则且自行承担风险,本站不退款、不进行额外附加服务;查看《如何避免下载的几个坑》。如果您已付费下载过本站文档,您可以点击 这里二次下载。
- 4、如文档侵犯商业秘密、侵犯著作权、侵犯人身权等,请点击“版权申诉”(推荐),也可以打举报电话:400-050-0827(电话支持时间:9:00-18:30)。
查看更多
SQLServer教案第09周 连接查询和子查询
授课日期 年月日 第周 授课形式 讲课 授课时数 章节名称 教学目的与要求 …On…子句进行多表自然连接查询
②掌握左外连接、右外连接和完全外连接
③掌握自连接查询
④掌握子查询的分类(单行子查询、多行子查询)
⑤掌握在Where子句中使用子查询作为查询条件
⑥掌握在From子句中使用子查询作为数据源
⑦掌握使用子查询在Insert Into语句中为数据表插入另一表中的已有数据。
⑧掌握使用子查询在update语句中进行基于外表条件的数据修改。
⑨掌握使用子查询在delete from语句中进行基于外表条件的数据删除。 教学重点 教学难点 教学方法和手段 讲授法结合课堂实例分析讨论 教学过程与组织 导入新课
讲授新课Select * From Student Inner Join SC On Student.SNo = SC.SNo
例:在上例中,只选取学号、姓名、课程号和成绩
Select SC.SNo, Student.SName, SC.CNo, SC.Grade From Student Inner Join SC On Student.SNo = SC.SNo
例:查询系编号为g001和g005各学生的选课情况和每门课的成绩,将每个系的名单排在一起
Select Student.SName, SC.CNo, SC.Grade From Student Inner Join SC On Student.SNo=SC.SNo Where Student.Depart=g001 Or Student.Depart = g005 Order By Student.Depart;
例:在上例中,使用表的别名
Select S.SName, SC.CNo, SC.Grade From Student S Inner Join SC On S.SNo=SC.SNo Where S.Depart = g001 Or S.Depart = g005 Order By S.Depart;
例:查询计算机系中选修了课程名为VB的课程的学生姓名和成绩
Select S.SName, C.CName, SC.Grade From Student S Join SC On S.SNo=SC.SNo Join Course C On C.CNo =SC.CNo Where S.Depart=g001 And C.CName=VB
例:查询所有选修了VB课程的学生姓名和所在系编号
Select S.SName, S.Depart From Student S Join SC On S.SNo=SC.SNo Join Course C On C.CNo=SC.CNo Where C.CName=VB
9.1.2 自连接
连接操作不仅可以在不同的表上进行,而且在同一张表内可以进行自身连接,即将同一个表的不同行连接起来。自连接可以看作一张表的两个副本之间的连接。在自连接中,必须为表指定两个别名,使之在逻辑上成为两张表。
自连接的处理思想是,将物理上的一个表,从逻辑上视同两个表。使用自连接必须为同一张表取两个别名,让一个表变成表名不同的两个表,仅此而已。其余的工作与两表连接查询无任何区别。
例:查询与冯巩在同一个系学习的学生的姓名和系编号
Select S2.SName, S2.Depart From Student S1 Join Student S2 On S1.Depart=S2.Depart Where S1.SName=冯巩 And S2.SName冯巩
9.1.3 外连接
外连接的思想是,当一个表中的元组,如果在另一表中找不到与其连接条件相匹配的元组时,并不将此元组的数据抛弃,而是将该元组的相关信息(结果中需要的列值)与连接的另一个表的空值列(全部取空值),也在形式上连接成新的元组,并将它置于查询结果中。这样一来,就达到了用户想保留某些信息的目的。
外连接是左外连接和右外连接的统称。语句结构和语法规则如下:
FROM 表1 LEFT | RIGHT [OUTER] JOIN 表2 ON 连接条件
LEFT [OUTER] JOIN 称作左外连接,RIGHT [OUTER] JOIN称作右外连接。
左外连接将在查询结果中,除了输出满足自然连接条件的结果外,还输出表1里面那些在表2找不到对应匹配的数据行的相关信息。
右外连接将在查询结果中,除了输出满足自然连接条件的结果外,还输出表2里面那些在表1找不到对应匹配的数据行的相关信息。
例:查询每个学生的学号、姓名、所选课程、成绩,即使有学生没有选课,也要列出他的信息
Select S.No, S.SName, SC.CNo, SC.Grade From Student S
文档评论(0)