有一张学生选课表
Table: Subject_Selection Subject Semester Attendee --------------------------------- ITB001 1 John ITB001 1 Bob ITB001 1 Mickey ITB001 2 Jenny ITB001 2 James MKB114 1 John MKB114 1 Erica
我们想统计每门课程有多少个学生报名
select subject,count(*) from
Subject_Selection
group by subject
得到如下结果
Subject Count ------------------------------ ITB001 5 MKB114 2
group by X意思是将所有相同的X字段的值的记录放在一个分组里
group by X,Y是将所有相同X字段值和Y字段值的记录放在一个分组里
我们接下来统计每门学科每学期有多少人选择
select subject,semester,count(*) from Subject_Selection group by subject,semester
上面sql的意思是,对subejct_selection表中的数据进行分组,将具有相同subject和semester字段值的记录放到同一个分组里去,然后对每个分组中的数据应用聚合函数(count,sum,avg,etc)
结果是:
Subject Semester Count ------------------------------ ITB001 1 3 ITB001 2 2 MKB114 1 2
从表中的记录我们可以看出这个分组结果是正确的,有3个学生在第一学期选择了ITB001,2个学生在第二学期选择了ITB001,还有两个学生在第一学期选择了MKB114,没人在第二学期选择MKB114