having和group by结合的使用

这是一个学生成绩表:

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
    点赞
  • 2
    收藏
    觉得还不错? 一键收藏
  • 0
    评论

“相关推荐”对你有帮助么?

  • 非常没帮助
  • 没帮助
  • 一般
  • 有帮助
  • 非常有帮助
提交
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值