这是一个学生成绩表:
mysql> desc sc;
+-------+-------------+------+-----+---------+-------+
| Field | Type | Null | Key | Default | Extra |
+-------+-------------+------+-----+---------+-------+
| sno | int(11) | NO | PRI | NULL |
| cno | int(11) | NO | PRI | NULL |
| grade | smallint(6) | NO | | 0
+-------+-------------+------+-----+---------+-------+
3 rows in set (0.02 sec)
// sno 是学号 cno是课程号 grade表示成绩
找出有三门课或三门课以上大于80分的学生?
1) 查询这个表中的数据
2) 执行select sno, cno, grade > 80 from sc;
看结果是不是发现只要成绩大于80的就是1,小于或等于80的就是0
3) 所以现在就可以使用 group by 和 having 实现前面的需求了:
select sno, sum(grade>80) as num from sc group by sno having num >= 3;
关键点:理解并知道 grade > 80 的结果是解决问题的关键,细节决定了高度!
也可以用这种写法实现这个需求:
/*
group by sno, 以学号进行分组之后,对于每一个组合中的记录,
使用 case when, 当grade > 80 就计数 1, 否则就计数为 0
*/
SELECT sno, SUM(CASE WHEN grade > 80 THEN 1 ELSE 0 END) num FROM sc GROUP BY sno HAVING num >= 3;