給定學生成績表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’;