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

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

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

悬赏问题

  • ¥50 C# 使用DEVMOD设置打印机首选项
  • ¥15 想用@vueuse 把项目动态改成深色主题,localStorge里面的vueuse-color-scheme一开始就给我改成了dark,不知道什么原因(相关搜索:背景颜色)
  • ¥20 OPENVPN连接问题
  • ¥15 flask实现搜索框访问数据库
  • ¥15 mrk3399刷完安卓11后投屏调试只能显示一个设备
  • ¥100 如何用js写一个游戏云存档
  • ¥15 ansys fluent计算闪退
  • ¥15 有关wireshark抓包的问题
  • ¥15 需要写计算过程,不要写代码,求解答,数据都在图上
  • ¥15 向数据表用newid方式插入GUID问题