数据库实验中出现的问题(回复).docVIP

  1. 1、本文档共5页,可阅读全部内容。
  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文档。上传文档
查看更多
数据库实验中出现的问题(回复)

1、查询每个学生的课程成绩最高的成绩信息(sno,cno,grade): (初始数据如下) 若执行select * from sc A where grade=(select max(grade) from sc where sno=A.sno ) order by A.sno ASC是正确的 但用select * from sc where grade in (select max(grade) from sc group by sno)的话就出现两条95001的记录,还是不明白什么原因,要是让我写语句我就会这样写。 知道为什么原因吗: 此处的原因的答案可以在实验四的第14题体现出来了. 只所以出现95001,85这条记录,是因为数据库在查找GRADE IN (92,90,85,85)成绩的时候,刚好95001当中有个学生的成绩是85分,所以它就把这个95001,85给显示出来了. 注意后者的写法是先求每个学生的最高成绩, 但这里面学号95003和95004的成绩都为85,这个没错,也出来了,关键是select * from sc where grade 这条语句的意思是求所有GRADE成绩为92,90,85,85的学生的记录, 但并没有说是求的某一个学生的最高成绩的记录. 这就是问题的根本所在. 你可以做个实验,把95001学生当中选修了2号课程的成绩85改为87, 那么得到的结论与你想要的结论是一样的(此时不存在两个95001了).可是此时,尽管答案是符合要求,但这种写法还是错了.要深刻理解它的原理和过程. 如下图所示: 第一种求法: select * from sc A where grade=(select max(grade) from sc where sno=A.sno ) order by A.sno ASC 是一个自身连接操作. 其操作步骤是: 先求95001, 找出95001的学生的最高成绩, 再求95002, 找出95002的最高成绩. 依此类推. 请看书本102面的例35的操作过程. 14*. 查询每个学生的课程成绩最高的成绩信息(sno,cno,grade): select * from sc A where grade= (select max(grade) from sc where sno=A.sno ) order by A.sno ASC (此处可否用GROUP by) select * from sc where grade in (select max(grade) from sc group by sno) (此答案有点问题: 当在数据库中同时有两个相同的最高分的,就出现判断错误.如95001里有一个最高分85, 95002里假如也有一个学生某门课成绩为85,这时问题就出现了.) select sc.sno, maxgrade from sc , (select sno, max(grade) as maxgrade from sc group by sno) as A where sc.sno=A.sno and grade=maxgrade (这种写法是正确的, 比较特殊的一种写法) 2、查询平均成绩少于70分的学生的学号。(以下是初始数据) 用Select sno from sc group by sno having avg(grade)70得到的数据跟分析表中应得到的一样(如下图) 执行此语句select sno from sc where not exists (Select sno from sc group by sno having avg(grade)=70)就没有结果,当外层查询取SC表中第一个元组,而此时内层查询返回值为FALSE,那外层查询中该元组的SNO就应该放入结果表中,然后再取SC表中下一个元组啊,真的不明白为什么会这样,请老师帮忙解决下。 注意: NOT EXISTS是空集判断,当集合中不存在任何元素(为空)时,其逻辑值为true,否则为false。关键是Select sno from sc group by sno having avg(grade)=70它得到的集合值非空, 也就是存在两个记录,如95002,95004. 因此, where not exists 这个条件没有为TRUE的情况, 那自然select sno from sc where not exists…..当然是空,没有SNO显示. 只有当where not exists 为空(也就是为TRUE)时,才会有显示的可能. 我们不妨做个实验: 将95001到95004学号的平均成绩都改成小于70分. 如: 95001 1 40 95

您可能关注的文档

文档评论(0)

cgtk187 + 关注
实名认证
文档贡献者

该用户很懒,什么也没介绍

1亿VIP精品文档

相关文档