shangqi8 2022-10-20 16:03 采纳率: 100%
浏览 566
已结题

学生数据库查询两门及以上不及格课程的学生姓名及其平均成绩

学生数据库查询两门及以上不及格课程的学生姓名及其平均成绩
学生数据库查询两门及以上不及格课程的学生姓名及其平均成绩
s_01表: (sno,sname)
sc_01表:(sno,cno,scgrade)
答案是这样的:
select s_01.sname,avg(sc_01.scgrade)
from s_01,sc_01 where s_01.sno=sc_01.sno
and
(select count(*) from sc_01 where s_01.sno=sc_01.sno and sc_01.scgrade<60)>=2
group by s_01.sname;
没有搞懂它的子查询的结果是什么,另外子查询中用了s_01表,为什么不用在子查询的where中写出来?

下面是我自己些的查询,效果和上面一样,有什么区别吗
select s_01.sname,avg(sc_01.scgrade)
from s_01,sc_01
where s_01.sno=sc_01.sno
and s_01.sno in
(select sc_01.sno from sc_01 where sc_01.scgrade<60 group by sc_01.sno having count(sc_01.sno)>=2)
group by sc_01.sno

  • 写回答

3条回答 默认 最新

  • CSDN专家-sinJack 2022-10-20 16:51
    关注

    实现方式有多种,很多方式都可以实现的。

    select s_01.sname,avg(sc_01.scgrade)
    from s_01,sc_01 where s_01.sno=sc_01.sno
    and
    (select count(*) from sc_01 where s_01.sno=sc_01.sno and sc_01.scgrade<60)>=2
    group by s_01.sname;
    

    答案是通过关联子查询的方式去实现的。通过一行行扫描s_01表的记录,每扫描一行记录,就判断当前记录的学生对应的成绩信息是否存在两门不合格的,如果存在,说明这条学生信息记录是满足where条件的。

    本回答被题主选为最佳回答 , 对您是否有帮助呢?
    评论
查看更多回答(2条)

报告相同问题?

问题事件

  • 系统已结题 10月28日
  • 已采纳回答 10月20日
  • 创建了问题 10月20日

悬赏问题

  • ¥20 机器学习能否像多层线性模型一样处理嵌套数据
  • ¥20 西门子S7-Graph,S7-300,梯形图
  • ¥50 用易语言http 访问不了网页
  • ¥50 safari浏览器fetch提交数据后数据丢失问题
  • ¥15 matlab不知道怎么改,求解答!!
  • ¥15 永磁直线电机的电流环pi调不出来
  • ¥15 用stata实现聚类的代码
  • ¥15 请问paddlehub能支持移动端开发吗?在Android studio上该如何部署?
  • ¥20 docker里部署springboot项目,访问不到扬声器
  • ¥15 netty整合springboot之后自动重连失效