暂无图片
暂无图片
暂无图片
暂无图片
暂无图片

MySQL HAVING

易语言mysql新手 2019-09-30
610

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


语法格式如下:

HAVING <条件>

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

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

1、WHERE 子句主要用于过滤数据行,而 HAVING 子句主要用于过滤分组,即 HAVING 子句基于分组的聚合值而不是特定行的值来过滤数据,主要用来过滤分组。

2、WHERE 子句不可以包含聚合函数,HAVING 子句中的条件可以包含聚合函数。

3、HAVING 子句是在数据分组后进行过滤,WHERE 子句会在数据分组前进行过滤。WHERE 子句排除的行不包含在分组中,可能会影响 HAVING 子句基于这些值过滤掉的分组。

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

mysql> SELECT dept_id,GROUP_CONCAT(name) AS names FROM 测试表1 GROUP BY dept_id HAVING COUNT(name)>1;

+---------+---------------+

| dept_id | names         |

+---------+---------------+

|       1 | Dany,Jane,Jim |

|       2 | Henry,John    |

|       3 | Green,Thomas  |

|       4 | Susan,Tom     |

+---------+---------------+

4 rows in set (0.07 sec)


本文分享自微信公众号 - 易语言mysql新手,如有侵权,请联系 service001@enmotech.com 删除。
最后修改时间:2019-12-20 10:06:57
文章转载自易语言mysql新手,如果涉嫌侵权,请发送邮件至:contact@modb.pro进行举报,并提供相关证据,一经查实,墨天轮将立刻删除相关内容。

评论