SQL Server数据库实践教程 课件 09-嵌套查询_第1页
SQL Server数据库实践教程 课件 09-嵌套查询_第2页
SQL Server数据库实践教程 课件 09-嵌套查询_第3页
SQL Server数据库实践教程 课件 09-嵌套查询_第4页
SQL Server数据库实践教程 课件 09-嵌套查询_第5页
已阅读5页,还剩10页未读 继续免费阅读

下载本文档

版权说明:本文档由用户提供并上传,收益归属内容提供方,若内容存在侵权,请进行举报或认领

文档简介

SQLServer数据库实践数据查询目录1、单表查询2、连接查询3、嵌套查询4、集合查询5、基于派生表的查询一个select,from后面只有一张表一个select,from后面多张表,按条件连接多个select,分为父查询和子查询多个select,平等的嵌套查询一个SELECT-FROM语句称为一个查询块。嵌套查询:

一条查询语句中有多个查询块,将一个查询块嵌套在另一个查询块的WHERE或HAVING子句中的查询。

SELECTCno,CnameFROMCourse

WHERECnonotin()嵌套查询:(多个SELECT-FROM查询块,分两步执行)

SELECTCnoFROMSC

--查询有学生选的课程号嵌套查询【例题5-31】没有学生选修的课程可能会取消,请你查询哪些课程没有学生选,显示课程号和课程名。用外连接可以实现此题目,在此要求用嵌套查询。外

接:(一个SELECT-FROM查询块,多张表都写在from后面)

SELECTCourse.Cno,CnameFROMCourseLEFTJOINSCONCourse.Cno=SC.CnoWHERESnoISNULL嵌套查询:(多个SELECT-FROM查询块,分两步执行)

SELECTCno,CnameFROMCourseWHERECnonotin

(SELECTCnoFROMSC)

嵌套查询【例题5-31】没有学生选修的课程可能会取消,请你查询哪些课程没有学生选,显示课程号和课程名。用外连接可以实现此题目,在此要求用嵌套查询。上层查询块称为外层查询或父查询下层查询块称为内层查询或子查询----外层查询或父查询----内层查询或子查询

嵌套查询SQL语言允许多层嵌套查询有些嵌套查询可以用连接查询替代

接:SELECTCourse.Cno,CnameFROMCourseLEFTJOINSCONCourse.Cno=SC.CnoWHERESnoISNULL嵌套查询:(多个SELECT-FROM查询块,分两步执行)

SELECTCno,CnameFROMCourseWHERECnonotin

(SELECTCnoFROMSC)内

接:

SELECT

SC.Cno,CnameFROMCourse,SCWHERECourse.Cno=

SC.

Cno

嵌套查询:SELECTCno,CnameFROMCourseWHERECno

in

(SELECTCnoFROMSC)

嵌套查询【题目】查询哪些课程有学生选,显示课程号和课程名,用嵌套查询。嵌套查询:(分两步执行)

SELECTNationFROMStudentWHEREName='南荷花'

嵌套查询【例题5-32】南荷花想认识同一民族的同学,请帮她查询有没有人和她同一个民族,用嵌套查询实现。

SELECTName,NationFROMStudentWHERENation=

(

)问题:为什么用Nation=,没用Nationin代码2:SELECT

TOP1Name,sex,BirthDayFROM

StudentORDERBY

BirthDay

DESC

嵌套查询【例题5-33】查找年龄最小的学生的姓名、性别和出生日期。代码1:SELECTName,sex,BirthDayFROMStudentWHEREBirthDay=(SELECTMAX(BirthDay)FROMStudent)问题:

两个代码执行效果一样吗?

嵌套查询【例题5-34】查询比平均学时高的课程的课程号、课程名和学时。SELECTCno课程号,Cname姓名,hours学时FROMCourseWHEREhours>(SELECTavg(hours)FROMCourse)问题:

还有其他方法吗?

嵌套查询【例题5-35】查询选修了数据库课程的学生的姓名和性别。不相关子查询:由里向外,一次性执行嵌套查询:(两层嵌套分三步执行)SELECTName,SexFROMStudentWHERESnoin(

SELECTSnoFROMSCWHERECnoin

(SELECTCnoFROMCourseWHERECname='数据库')

)

嵌套查询不相关子查询:相关子查询:子查询不依赖于父查询,可独立执行由里向外逐层处理,一次性执行。先执行子查询,子查询的结果用于建立其父查询的查询条件。子查询的查询条件依赖于父查询外→里→外,反复多次先取外层查询结果中第一个元组,相关的属性值传入内层查询若内层查询WHERE子句返回值为真,则此元组放入结果表再取外层查询中下一个元组重复这一过程,直至外层结果全部检查完为止不相关子查询示例:SELECTCno,Cname

FROMCourseWHERECnonotin

(SELECTCnoFROMSC)嵌套查询(相关子查询)【例题5-36】查询每个学生超过他自己选修课程的平均成绩的课程号。嵌套查询:(相关子查询)SELECTSno,CnoFROMSCs1WHEREGrade>(SELECTavg(Grade)FROMSCWHERESno=s1.Sno)先取外层查询结果中第一个元组,相关的属性值传入内层查询若内层查询WHERE子句返回值为真,则此元组放入结果表再取外层查询中下一个元组重复这一过程,直至外层结果全部检查完为止嵌套查询(相关子查询)①外层查询取SC的一个元组,将Sno值(1001)传送给内层查询。

SELECTavg(Grade)FROMSCWHERESno=1001②执行内层查询,得到值90,用该值代替内层查询,得到外层查询:

SELECTSno,CnoFROMSCs1WHEREGrade>90

分析执行过程:SELECTSno,Cno

温馨提示

  • 1. 本站所有资源如无特殊说明,都需要本地电脑安装OFFICE2007和PDF阅读器。图纸软件为CAD,CAXA,PROE,UG,SolidWorks等.压缩文件请下载最新的WinRAR软件解压。
  • 2. 本站的文档不包含任何第三方提供的附件图纸等,如果需要附件,请联系上传者。文件的所有权益归上传用户所有。
  • 3. 本站RAR压缩包中若带图纸,网页内容里面会有图纸预览,若没有图纸预览就没有图纸。
  • 4. 未经权益所有人同意不得将文件中的内容挪作商业或盈利用途。
  • 5. 人人文库网仅提供信息存储空间,仅对用户上传内容的表现方式做保护处理,对用户上传分享的文档内容本身不做任何修改或编辑,并不能对任何下载内容负责。
  • 6. 下载文件中如有侵权或不适当内容,请与我们联系,我们立即纠正。
  • 7. 本站不保证下载资源的准确性、安全性和完整性, 同时也不承担用户因使用这些下载资源对自己和他人造成任何形式的伤害或损失。

评论

0/150

提交评论