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
- having和group by结合的使用
- Having和Group by的使用
- group by having limit结合使用实例
- group by having的使用
- 查询之order by,group by和having的使用
- 查询之order by,group by和having的使用
- 查询之order by,group by和having的使用
- 查询之order by,group by和having的使用 .
- HQL的group by和having的使用
- sql语句中GROUP BY 和 HAVING的使用 count()
- sql语句中GROUP BY 和 HAVING的使用
- sql语句中GROUP BY 和 HAVING的使用 count()
- sql语句中GROUP BY 和 HAVING的使用 count()
- sql语句中GROUP BY 和 HAVING的使用 count()
- sql语句中GROUP BY 和 HAVING的使用 count()
- sql语句中GROUP BY 和 HAVING的使用 count()
- sql语句中having count 和group by的使用
- sql语句中GROUP BY 和 HAVING的使用 count()
- Java类加载原理解析
- VirtualBox打开克隆或复制的.vdi或.vmdk文件的UUID问题
- Cloudera hadoop配置文件地址和修改配置属性方法
- WinDbg+WMware+OS_Win7 配置
- Canvas类绘制几何图形
- having和group by结合的使用
- 修改Ubuntu主机名
- “上门+到店”能救活汽车后市场吗?
- cognos RS 进度条
- java提高篇(十)-----强制类型转换
- 随机梯度下降与梯度下降
- 解决虚拟机中ubuntu无法识别U盘
- Android 主流网络图片加载缓存库框架Universal-ImageLoader的使用
- HihoCoder(79 -80weeks)