版权说明:本文档由用户提供并上传,收益归属内容提供方,若内容存在侵权,请进行举报或认领
文档简介
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. 本站不保证下载资源的准确性、安全性和完整性, 同时也不承担用户因使用这些下载资源对自己和他人造成任何形式的伤害或损失。
最新文档
- 基于大数据的学前儿童健康行为分析及对策研究报告
- 护理实践中的循证依据
- 护理安全评估:患者安全评估的准确性
- 医院感染监测与数据分析
- 基于大数据的智能传感器性能分析报告
- 呼吸系统疾病护理的临床案例分享
- 客户服务团队的领导力与面试技巧
- 链家房产销售顾问面试全解析
- 零售业财务主管招聘面试全攻略
- 人教版五年级下册数学第七单元测试卷(折线统计图)含答案解析
- TCI 373-2024 中老年人免散瞳眼底疾病筛查规范
- 河南省中小学校本课程建设案例评选申报表
- 组织机构设置、人员配置及职责分工
- 天疱疮护理查房
- 学生心理健康一生一策档案模板
- 2024年海南省农垦投资控股集团有限公司招聘笔试参考题库含答案解析
- 高危药品管理护理课件
- 中职数学基础模块下册第8.4.1《圆的标准方程》说课课件
- 教育评价与考试改革的实践与成果培训课件
- S快递公司服务质量问题及研究对策 工商管理专业
- 水影响评价报告编制收费标准
评论
0/150
提交评论