10、 HAVING:过滤分组
在 MySQL 中,可以使用 HAVING 关键字对分组后的数据进行过滤。
使用 HAVING 关键字的语法格式如下:
HAVING <查询条件>
HAVING 关键字和 WHERE 关键字都可以用来过滤数据,且 HAVING 支持 WHERE 关键字中所有的操作符和语法。
但是 WHERE 和 HAVING 关键字也存在以下几点差异:
- 一般情况下,WHERE 用于过滤数据行,而 HAVING 用于过滤分组。
WHERE 查询条件中不可以使用聚合函数
,而 HAVING 查询条件中可以使用聚合函数。- WHERE 在数据分组前进行过滤,而 HAVING 在数据分组后进行过滤 。
- WHERE 针对数据库文件进行过滤,而 HAVING 针对查询结果进行过滤。也就是说,WHERE 根据数据表中的字段直接进行过滤,而
HAVING 是根据前面已经查询出的字段进行过滤。 - WHERE 查询条件中不可以使用字段别名,而 HAVING 查询条件中可以使用字段别名。
下面通过实例让大家更直观的了解 WHERE 和 HAVING 关键字的相同点和不同点。
例 1
分别使用 HAVING 和 WHERE 关键字查询出 tb_students_info 表中身高大于 150 的学生姓名,性别和身高。SQL 语句和运行结果如下。
HAVING
mysql> SELECT name,sex,height FROM tb_students_info -> HAVING height>150;
+--------+------+--------+
| name | sex | height |
+--------+------+--------+
| Dany | 男 | 160 |
| Green | 男 | 158 |
| Henry | 女 | 185 |
| Jane | 男 | 162 |
| Jim | 女 | 175 |
| John | 女 | 172 |
| Lily | 男 | 165 |
| Susan | 男 | 170 |
| Thomas | 女 | 178 |
| Tom | 女 | 165 |
+--------+------+--------+
WHERE
mysql> SELECT name,sex,height FROM tb_students_info -> WHERE height>150;
+--------+------+--------+
| name | sex | height |
+--------+------+--------+
| Dany | 男 | 160 |
| Green | 男 | 158 |
| Henry | 女 | 185 |
| Jane | 男 | 162 |
| Jim | 女 | 175 |
| John | 女 | 172 |
| Lily | 男 | 165 |
| Susan | 男 | 170 |
| Thomas | 女 | 178 |
| Tom | 女 | 165 |
+--------+------+--------+
上述实例中,因为在 SELECT 关键字后已经查询出了 height 字段,所以 HAVING 和 WHERE 都可以使用。但是如果 SELECT 关键字后没有查询出 height 字段,使用HAVING的MySQL语句 就会报错
。
例 2
使用 HAVING 和 WHERE 关键字分别查询出 tb_students_info 表中身高大于 150 的学生姓名和性别(与例 1 相比,这次没有查询 height 字段)。SQL 语句和运行结果如下。
WHERE
mysql> SELECT name,sex FROM tb_students_info -> WHERE height>150;
+--------+------+
| name | sex |
+--------+------+
| Dany | 男 |
| Green | 男 |
| Henry | 女 |
| Jane | 男 |
| Jim | 女 |
| John | 女 |
| Lily | 男 |
| Susan | 男 |
| Thomas | 女 |
| Tom | 女 |
+--------+------+
HAVING
mysql> SELECT name,sex FROM tb_students_info HAVING height>150;
ERROR 1054 (42S22): Unknown column 'height' in 'having clause'
由结果可以看出,如果 SELECT 关键字后没有查询出 HAVING 查询条件中使用的 height 字段,MySQL 会提示错误信息:“having子句”中的列“height”未知”。
例 3
根据 height 字段对 tb_students_info 表中的数据进行分组,并使用 HAVING 和 WHERE 关键字分别查询出分组后平均身高大于 170 的学生姓名、性别和身高。SQL 语句和运行结果如下。
mysql> SELECT GROUP_CONCAT(name),sex,height FROM tb_students_info -> GROUP BY height -> HAVING AVG(height)>170;
+--------------------+------+--------+
| GROUP_CONCAT(name) | sex | height |
+--------------------+------+--------+
| John | 女 | 172 |
| Jim | 女 | 175 |
| Thomas | 女 | 178 |
| Henry | 女 | 185 |
+--------------------+------+--------+
mysql> SELECT GROUP_CONCAT(name),sex,height FROM tb_students_info WHERE AVG(height)>170 GROUP BY height;ERROR 1111 (HY000): Invalid use of group function
由结果可以看出,如果在 WHERE 查询条件中使用聚合函数,MySQL 会提示错误信息:无效使用组函数。
10、 HAVING:过滤分组相关推荐
- MySQL过滤分组关键字_MySQL教程76-HAVING 过滤分组
在 MySQL 中,可以使用 HAVING 关键字对分组后的数据进行过滤. 使用 HAVING 关键字的语法格式如下: HAVING HAVING 关键字和 WHERE 关键字都可以用来过滤数据,且 ...
- mysql十分钟分组_MYSQL每隔10分钟进行分组统计的实现方法
前言 本文的内容主要是介绍了mysql每隔10分钟进行分组统计的实现方法,在画用户登录.操作情况在一天内的分布图时会非常有用,之前我只知道用「存储过程」实现的方法(虽然执行速度快,但真的是太不灵活了) ...
- 【SQL】分组数据,过滤分组-group by , having
学习笔记,原文来自http://blog.csdn.net/robinjwong/article/details/24845125 创建分组 - GROUP BY 分组是在SELECT语句的GROUP ...
- 皕杰报表中的过滤分组函数与过滤分组报表
过滤分组报表是什么样的呢?见下图. 从图中可以看出,"华北"组中的一部分记录被过滤,并单独拎出来在"其中:北京"组和"其中:天津"组中进行了 ...
- java8 stream流操作集合交集,差集,并集,过滤,分组,去重,排序,聚合等
测试对象 public class Person {private String name;private Integer age;private Integer weight;public Pers ...
- oracle 按每分钟分组,oracle按每个10分钟进行分组展示数据
例如 有这么一张表 XATXDAY_FLIGHT(航班飞航表), 有这么一个字段 STD_LOCAL(起飞时间), 要求:统计一天24小时之内每隔10分钟,这10分钟之内有几架飞机起飞. 比如:XAT ...
- ReportViewer教程(10)-给报表分组合计
选择主体内的"table1"表(点击它一下即选中), 再右击它的最左上角方块: 右击后调出菜单,如下图: 选择菜单上"属性",调出"表属性" ...
- Python之10人比赛分组
背景 最近公司准备举行王者荣耀夏季清凉赛,作为会长,当然要write点code来show一下了.这是典型的十人随机分组,也就下班的时候随便写,没有经过太多思考也没有太多封装优化等等,下次再写点厉害的吧 ...
- 数据库笔记 NO.1 ------------2020.03.26
***排序与检索数据*** ---检索多个列 select prod_id, prod_name, prod_price from Products; ---检索所有列 select * from P ...
最新文章
- ccf压缩编码java_压缩编码(CCF)——动态规划
- python脚本忽略MySQLdb的warnings
- Matlab符号运算 - 解微分方程
- 实现透明渐变的Activity
- jvm性能调优 - 10白话年轻代数据晋升老年代规则及老年代回收算法
- python 3.x 爬虫基础---http headers详解
- 轻松理解Spring框架的基本思想
- 《深度学习》学习的TIP
- 机器视觉【基础】什么是机器视觉?
- 一个编程指南还有这么多道道儿?
- 数据安全_个人信息查询
- 洛谷3916 图的遍历
- 文本处理命令系列——cut
- paip.提升用户体验---提取FLASH中图片
- 601. 体育馆的人流量
- PTA 数据结构与算法 7-46 新浪微博热门话题
- 第八周【任务1】神经网络推理加速(笔记)
- element表格固定表头每列宽度,最右侧固定后,溢出出现滚动条内容和表头不能同时移动
- mysql的column是什么意思_column意思 数据库中的column是什么意思
- undefined和is not defined区别
热门文章
- NLP:两种方法(自定义函数和封装函数)实现提取两人对话内容(***分隔txt文档),并各自保存为txt文档
- c++ string 字符串
- 可变数组集合ArrayList
- 多媒体文件格式之RMVB
- [转] 书摘及访谈:Aptana RadRails,一个Rails的集成开发环境
- 编译成功但链接失败的原因
- SysTick的优先级是高还是低
- java找出价格最低_SQL查询查找每个零件的最低价格的供应商
- 波卡链Substrate (2)系统框架
- C++ Primer 5th笔记(9)chapter9 顺序容器 string