




版权说明:本文档由用户提供并上传,收益归属内容提供方,若内容存在侵权,请进行举报或认领
文档简介
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年高效的锅炉鼓、引风机项目发展计划
- 系统解剖学试题(附参考答案)
- 2025年环保节能型冷却塔项目合作计划书
- 物业管理企业财务管理规定
- 武汉体育学院附属体育运动学校招聘真题
- 动物园动物饲养区的安全管理措施
- ICU医院感染管理制度
- 小学生心理健康与辅导(第4版) 课件 第七章 小学生常见心理行为问题与辅导
- Unit 8 Section A (1a-1c) 教学设计2024-2025学年人教版八年级英语上册
- 2025年3月版安全环境职业健康法律法规标准文件清单
- 《心律失常患者的护理指南》课件
- 《班组管理培训》课件
- 2025年个人资产出售与收购协议书
- 2025年度人力资源居间费合同范本:人才招聘中介服务协议
- 污水处理厂设计中的安全措施与管理
- 血小板制备纯度提升策略-洞察分析
评论
0/150
提交评论