1. 程式人生 > 實用技巧 >SQL分組聚合查詢

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=‘1’ 
2 UNION select son from sc where grade is null and cno=‘1’;