SQL 50题

允我心安 提交于 2019-11-27 13:29:34

11.查询两⻔门及其以上不不及格课程的同学的学号,姓名及其平均成绩
+先把不及格的抓出来找两个以上不及格的

select Student.Sid,Sname,ssc.ave from Student,
    (select Sid,avg(score) as ave from SC group by Sid)ssc 
    where Student.Sid = ssc.Sid 
    and Student.Sid in 
        (select t.Sid from   
             (select Sid from SC where score < 60) t 
        group by t.Sid having count(t.Sid) > 2
    );

+按人学号进行分组,找出其中两个以上不及格的
--?bug

 select student.sname,avg(sc.score)  from sc,student right join ( select t.sid,count(t.sid) from (select sid,score from sc where score <60)t group by t.sid having count(*)>1)ss on student.sid = ss.sid where sc.sid = ss.sid;
标签
易学教程内所有资源均来自网络或用户发布的内容,如有违反法律规定的内容欢迎反馈
该文章没有解决你所遇到的问题?点击提问,说说你的问题,让更多的人一起探讨吧!