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

学生数据库查询两门及以上不及格课程的学生姓名及其平均成绩
学生数据库查询两门及以上不及格课程的学生姓名及其平均成绩
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

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

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条件的。

他的子查询是 通过每个学生去查,判断是否有两门成绩不合格,
你的查询是 先分组把两门成绩不合格的学生学号找出来,然后再根据查出来的学号去查询姓名及其平均成绩

您好,我是有问必答小助手,您的问题已经有小伙伴帮您解答,感谢您对有问必答的支持与关注!
PS:问答VIP年卡 【限时加赠:IT技术图书免费领】,了解详情>>> https://vip.csdn.net/askvip?utm_source=1146287632