单元4高级查询-5解说.pptVIP

  1. 1、本文档共40页,可阅读全部内容。
  2. 2、原创力文档(book118)网站文档一经付费(服务费),不意味着购买了该文档的版权,仅供个人/单位学习、研究之用,不得用于商业用途,未经授权,严禁复制、发行、汇编、翻译或者网络传播等,侵权必究。
  3. 3、本站所有内容均由合作方或网友上传,本站不对文档的完整性、权威性及其观点立场正确性做任何保证或承诺!文档内容仅供研究参考,付费前请自行鉴别。如您付费,意味着您自己接受本站规则且自行承担风险,本站不退款、不进行额外附加服务;查看《如何避免下载的几个坑》。如果您已付费下载过本站文档,您可以点击 这里二次下载
  4. 4、如文档侵犯商业秘密、侵犯著作权、侵犯人身权等,请点击“版权申诉”(推荐),也可以打举报电话:400-050-0827(电话支持时间:9:00-18:30)。
  5. 5、该文档为VIP文档,如果想要下载,成为VIP会员后,下载免费。
  6. 6、成为VIP后,下载本文档将扣除1次下载权益。下载后,不支持退款、换文档。如有疑问请联系我们
  7. 7、成为VIP后,您将拥有八大权益,权益包括:VIP文档下载权益、阅读免打扰、文档格式转换、高级专利检索、专属身份标志、高级客服、多端互通、版权登记。
  8. 8、VIP文档为合作方或网友上传,每下载1次, 网站将根据用户上传文档的质量评分、类型等,对文档贡献者给予高额补贴、流量扶持。如果你也想贡献VIP文档。上传文档
查看更多
* * * 超过3名学生提问 或 编码过程中遇到的问题需要集中讲解。 * 指导——嵌套SELECT子句的子查询2-1 训练要点: 任何允许使用表达式的地方都可以使用子查询 需求说明: 为每个学生制作在校期间每门课程的成绩单,要求每个学生参加每门课程的最后一次考试成绩作为该生本课程的最终成绩 成绩单中包括: 学生姓名 课程所属的年级名称 课程名称 考试日期 考试成绩 讲解需求说明 指导——嵌套SELECT子句的子查询2-2 实现思路: 使用分组查询获得每门课程最近一次考试的日期 使用联接查询得到每门课程最近一次考试成绩的学生姓名、课程名称、考试日期和成绩 在父查询的SELECT子句中使用子查询获得年级名称 完成时间:25分钟 SELECT StudentName 姓名, ( SELECT GradeName FROM Grade WHERE GradeId=Subject.GradeId ) 课程所属年级, SubjectName 课程名称, ExamDate 考试日期, StudentResult 成绩 FROM Result INNER JOIN Student ON Result.StudentNo=Student.StudentNo INNER JOIN Subject ON Subject.SubjectNo=Result.SubjectNo WHERE Result.ExamDate = ( SELECT Max(ExamDate) FROM Result WHERE SubjectNo=Subject.SubjectNo AND StudentNo=Student.StudentNo GROUP BY Result.SubjectNo ) ORDER BY Result.StudentNo ASC,Result.SubjectNo ASC 子查询嵌套在父查询的WHERE子句中,得到每门课程最近一次考试的成绩 实现同一个数据查询功能可以有多种方法,每次编码调试成功后,你可以再想想是否还有其他更好的方法 子查询嵌套在父查询的SELECT子句中,得到年级名称 指导——SQL语句的综合应用5-1 训练要点: 综合运用T-SQL语句实现业务处理 需求说明: 统计 “Java”课程考试的学生合格率 学生信息表和成绩表 应到人数:5人 实到人数4人,缺考1人 如何实现? 本次考试的缺考情况 比较考试平均分,较低者进行循环提分,但提分后最高分不能超过97分 。加分后重新统计通过情况 统计通过率 子查询注意事项 任何允许使用表达式的地方都可以使用子查询 嵌套在父查询SELECT语句的子查询可包括: SELECT子句 FROM子句 WHERE子句 GROUP BY子句 HAVING子句 TEXT、NTEXT和IMAGE数据类型列不能出现在子查询的SELECT子句中 只出现在子查询中而没有出现在父查询中的表不能包含在输出列中 可选子句,根据业务需求决定 指导——SQL语句的综合应用5-2 需求说明: 统计 “Java”课程考试学生应到人数、实到人数 提取“Java”课程考试的成绩信息并保存结果 成绩信息(学生姓名、学号、成绩、是否通过) 实现思路: 声明并初始化变量 使用子查询统计缺考情况 将考试成绩保存到表TempResult中 指导——SQL语句的综合应用5-3 1. 使用查询获得“Java Logic”课程的课程编号和最近一次考试日期 --声明并初始化变量: DECLARE @subjectName varchar(50) DECLARE @date datetime --最近考试时间 DECLARE @subjectNo int --课程编号 SET @subjectName=Java Logic SELECT @date=max(ExamDate) FROM Result INNER JOIN Subject ON Result.SubjectNo=Subject.SubjectNo WHERE SubjectName= @subjectName SELECT @subjectNo=subjectNo FROM Subject WHERE SubjectName= @subjectName 2.提示: 使用子查询统计缺考情况: 应到人数:SELECT COUNT(*) FROM Student INNER JOIN Subject ON Subject.GradeId=Student.GradeId WHER

文档评论(0)

希望之星 + 关注
实名认证
文档贡献者

我是一名原创力文库的爱好者!从事自由职业!

1亿VIP精品文档

相关文档