码迷,mamicode.com
首页 > 数据库 > 详细

MySQL之指定过滤条件(HAVING)

时间:2020-01-12 11:24:50      阅读:87      评论:0      收藏:0      [点我收藏+]

标签:box   存在   聚合函数   HERE   sele   where   结果   sql   根据   

在 MySQL SELECT 语句中,除了能使用 GROUP BY 子句分组数据外,还可以使用 HAVING 子句过滤分组,在结果集中规定了包含哪些分组和排除哪些分组。

语法格式如下:

HAVING <条件>


其中,<条件>指的是指定的过滤条件。

HAVING 子句和 WHERE 子句非常相似,HAVING 子句支持 WHERE 子句中所有的操作符和语法,但是两者存在几点差异:

  • WHERE 子句主要用于过滤数据行,而 HAVING 子句主要用于过滤分组,即 HAVING 子句基于分组的聚合值而不是特定行的值来过滤数据,主要用来过滤分组。
  • WHERE 子句不可以包含聚合函数,HAVING 子句中的条件可以包含聚合函数。
  • HAVING 子句是在数据分组后进行过滤,WHERE 子句会在数据分组前进行过滤。WHERE 子句排除的行不包含在分组中,可能会影响 HAVING 子句基于这些值过滤掉的分组。


【实例】根据 dept_id 对 tb_students_info 表中的数据进行分组,并显示学生人数大于1的分组信息,输入的 SQL 语句和执行结果如下所示。

技术图片

 

 不进行HAVING条件过滤查询结果如下:

技术图片

MySQL之指定过滤条件(HAVING)

标签:box   存在   聚合函数   HERE   sele   where   结果   sql   根据   

原文地址:https://www.cnblogs.com/ccstu/p/12182111.html

(0)
(0)
   
举报
评论 一句话评论(0
登录后才能评论!
© 2014 mamicode.com 版权所有  联系我们:gaon5@hotmail.com
迷上了代码!