SQL分組聚合查詢


  給定學生成績表SG,包含三個字端(sno, cla, grade) 分別代表學生學號、班級、學生分數。

 

 要求查詢每個班的不及格人數:

1 select cla, count(sno) from SG where grade<60 group by cla;

 

  查詢每個班的不及格人數和及格人數,之前我想的是用union去做,但是union是集合操作,並不能將及格人數和不及格人數分為兩個字段而展示,正確的是這種分組的查詢方式: 

1 select cla, 2     sum( if (grade >= 60, 1, 0)) as ‘及格', 3  sum(if (grade < 60, 1, 0)) as '不及格' , 4  count(*) as '總 人數'  
5  from SG group by cla order by cla;

或者 

1 select 
2  cla, 3     sum( case when grade >= 60 then 1 else 0 end) as '及格', 4     sum(case when grade < 60 then 1 else 0 end) as '不及格', 5     count(*) as '總人數'  
6     from SG group by cla order by cla;

 

 

  針對聚合操作和集合操作,常見的聚合操作比如 COUNT(*)、SUM(<列名>)、AVG(<列名>),得到的是一列值的個數、總和、以及平均值。而對於集合操作比如 UNION、INTERSECT、EXCEPT 代表對查詢出來的集合分別取並集、交集、補集。且集合查詢必須保證查詢的列數相同,對應項的數據類型相同。對於新表 SC[sno, cno, grade] 分別代表學號、課程、分數,如要查詢選出選修了 1 號課程的不及格的學生以及缺考的學生:

1 select sno from sc where grade <60 and cno=12 UNION select son from sc where grade is null and cno=1’;


免責聲明!

本站轉載的文章為個人學習借鑒使用,本站對版權不負任何法律責任。如果侵犯了您的隱私權益,請聯系本站郵箱yoyou2525@163.com刪除。



 
粵ICP備18138465號   © 2018-2025 CODEPRJ.COM