在 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:过滤分组相关推荐

  1. MySQL过滤分组关键字_MySQL教程76-HAVING 过滤分组

    在 MySQL 中,可以使用 HAVING 关键字对分组后的数据进行过滤. 使用 HAVING 关键字的语法格式如下: HAVING HAVING 关键字和 WHERE 关键字都可以用来过滤数据,且 ...

  2. mysql十分钟分组_MYSQL每隔10分钟进行分组统计的实现方法

    前言 本文的内容主要是介绍了mysql每隔10分钟进行分组统计的实现方法,在画用户登录.操作情况在一天内的分布图时会非常有用,之前我只知道用「存储过程」实现的方法(虽然执行速度快,但真的是太不灵活了) ...

  3. 【SQL】分组数据,过滤分组-group by , having

    学习笔记,原文来自http://blog.csdn.net/robinjwong/article/details/24845125 创建分组 - GROUP BY 分组是在SELECT语句的GROUP ...

  4. 皕杰报表中的过滤分组函数与过滤分组报表

    过滤分组报表是什么样的呢?见下图. 从图中可以看出,"华北"组中的一部分记录被过滤,并单独拎出来在"其中:北京"组和"其中:天津"组中进行了 ...

  5. java8 stream流操作集合交集,差集,并集,过滤,分组,去重,排序,聚合等

    测试对象 public class Person {private String name;private Integer age;private Integer weight;public Pers ...

  6. oracle 按每分钟分组,oracle按每个10分钟进行分组展示数据

    例如 有这么一张表 XATXDAY_FLIGHT(航班飞航表), 有这么一个字段 STD_LOCAL(起飞时间), 要求:统计一天24小时之内每隔10分钟,这10分钟之内有几架飞机起飞. 比如:XAT ...

  7. ReportViewer教程(10)-给报表分组合计

    选择主体内的"table1"表(点击它一下即选中), 再右击它的最左上角方块: 右击后调出菜单,如下图: 选择菜单上"属性",调出"表属性" ...

  8. Python之10人比赛分组

    背景 最近公司准备举行王者荣耀夏季清凉赛,作为会长,当然要write点code来show一下了.这是典型的十人随机分组,也就下班的时候随便写,没有经过太多思考也没有太多封装优化等等,下次再写点厉害的吧 ...

  9. 数据库笔记 NO.1 ------------2020.03.26

    ***排序与检索数据*** ---检索多个列 select prod_id, prod_name, prod_price from Products; ---检索所有列 select * from P ...

最新文章

  1. ccf压缩编码java_压缩编码(CCF)——动态规划
  2. python脚本忽略MySQLdb的warnings
  3. Matlab符号运算 - 解微分方程
  4. 实现透明渐变的Activity
  5. jvm性能调优 - 10白话年轻代数据晋升老年代规则及老年代回收算法
  6. python 3.x 爬虫基础---http headers详解
  7. 轻松理解Spring框架的基本思想
  8. 《深度学习》学习的TIP
  9. 机器视觉【基础】什么是机器视觉?
  10. 一个编程指南还有这么多道道儿?
  11. 数据安全_个人信息查询
  12. 洛谷3916 图的遍历
  13. 文本处理命令系列——cut
  14. paip.提升用户体验---提取FLASH中图片
  15. 601. 体育馆的人流量
  16. PTA 数据结构与算法 7-46 新浪微博热门话题
  17. 第八周【任务1】神经网络推理加速(笔记)
  18. element表格固定表头每列宽度,最右侧固定后,溢出出现滚动条内容和表头不能同时移动
  19. mysql的column是什么意思_column意思 数据库中的column是什么意思
  20. undefined和is not defined区别

热门文章

  1. NLP:两种方法(自定义函数和封装函数)实现提取两人对话内容(***分隔txt文档),并各自保存为txt文档
  2. c++ string 字符串
  3. 可变数组集合ArrayList
  4. 多媒体文件格式之RMVB
  5. [转] 书摘及访谈:Aptana RadRails,一个Rails的集成开发环境
  6. 编译成功但链接失败的原因
  7. SysTick的优先级是高还是低
  8. java找出价格最低_SQL查询查找每个零件的最低价格的供应商
  9. 波卡链Substrate (2)系统框架
  10. C++ Primer 5th笔记(9)chapter9 顺序容器 string