版权说明:本文档由用户提供并上传,收益归属内容提供方,若内容存在侵权,请进行举报或认领
文档简介
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. 本站不保证下载资源的准确性、安全性和完整性, 同时也不承担用户因使用这些下载资源对自己和他人造成任何形式的伤害或损失。
最新文档
- 《翰威特职业测试》课件
- 2025年中考英语一轮教材复习 写作话题6 健康与安全
- 毛泽东思想和中国特色社会主义理论体系概论(黑龙江农业经济职业学院)知到智慧树答案
- 《综合英语》单元试卷quiz 4
- 石油炼制工程课件
- 《教学方法和技巧》课件
- (部编版八年级《政治》课件)第1课时-维护秩序
- 《空椅子技术》课件
- 医学检验实验室应有危害评估体系及规范的危害评估报告
- 会计审计人员聘用合同样本
- 中国56个民族标徽
- (完整版)假设检验习题及答案
- 地下室赶工措施方案(终版)
- 民用机场工程造价控制的难点浅析
- 医疗机构临床用血管理的通知
- 化工原理课程设计--用水冷却乙酸甲酯列管式换热器设计
- 诺基亚LTE基站简介
- 电力工程监理项目部标准技术清单汇编(光伏及风电工程)
- 换电站设计说明书
- EORTC生命质量测定量表QLQ-C30(V3.0).doc
- 医学交流课件:特布他林雾化吸入治疗 ——药理学视角
评论
0/150
提交评论