having和group by结合的使用

来源:互联网 发布:台湾视频软件 编辑:程序博客网 时间:2024/05/17 06:03

这是一个学生成绩表:

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;
0 0
原创粉丝点击