当前位置: 首页 >数据库 > 【MySQL】分组数据(GROUP BY 和 HAVING)

【MySQL】分组数据(GROUP BY 和 HAVING)

1. 在具体使用GROUP BY子句前,需要知道一些重要的规定

  • GROUP BY子句可以包含任意数目的列。这使得能对分组进行嵌套,为数据分组提供更细致的控制。
  • 如果在GROUP BY子句中嵌套了分组,数据将在最后规定的分组上进行汇总。换句话说,在建立分组时,指定的所有列都一起计算(所以不能从个别的列取回数据)。
  • GROUP BY子句中列出的每个列都必须是检索列或有效的表达式(但不能是聚集函数)。如果在SELECT中使用表达式,则必须在GROUP BY子句中指定相同的表达式。不能使用别名。
  • 除聚集计算语句外,SELECT语句中的每个列都必须在GROUP BY子句中给出。
  • 如果分组列中具有NULL值,则NULL将作为一个分组返回。如果列中有多行NULL值,它们将分为一组。
  • GROUP BY子句必须出现在WHERE子句之后,ORDER BY子句之前。

【注】:使用WITH ROLLUP关键字,可以得到每个分组(包括NULL)以及每个分组汇总级别(针对每个分组)的值。如下(运行结果,左图):

SELECT spancount, COUNT(*)FROM articleGROUP BY spancount WITH ROLLUP; 

未加WITH ROLLUP的查询(结果如,右图):

SELECT spancount, COUNT(*)FROM articleGROUP BY spancount; 

【MySQL】分组数据(GROUP BY 和 HAVING) _ JavaClub全栈架构师技术笔记            【MySQL】分组数据(GROUP BY 和 HAVING) _ JavaClub全栈架构师技术笔记

2. 过滤分组(HAVING)

WHERE过滤指定的是行而不是分组。事实上,WHERE没有分组的概念。

那么,不使用WHERE使用什么呢?MySQL为此目的提供了另外的子句,那就是HAVING子句。HAVING非常类似于WHERE。事实上,目前为止所学过的所有类型的WHERE子句都可以用HAVING来替代。唯一的差别是WHERE过滤行,而HAVING过滤分组。HAVING支持所有WHERE操作符。

SELECT spancount, COUNT(*)FROM articleGROUP BY spancountHAVING count(*) > 10; 

【MySQL】分组数据(GROUP BY 和 HAVING) _ JavaClub全栈架构师技术笔记

【注】:HAVING和WHERE的差别

这里有另一种理解方法,WHERE在数据分组前进行过滤,HAVING在数据分组后进行过滤。这是一个重要的区别,WHERE排除的行不包括在分组中。这可能会改变计算值,从而影响HAVING子句中基于这些值过滤掉的分组。

3. 分组和排序

虽然GROUP BY和ORDER BY经常完成相同的工作,但它们是非常不同的。

表1. ORDER BY与GROUP BY
ORDER BYGROUP BY
排序产生的输出分组行。但输出可能不是分组的顺序
任意列都可以使用(甚至非选择的列也可以使用)只可能使用选择列或表达式列,而且必须使用每个选择列表达式
不一定需要如果与聚集函数一起使用列(或表达式),则必须使用

【注】:不要忘记ORDER BY

一般在使用GROUP BY子句时,应该也给出ORDER BY子句。这是保证数据正确排序的唯一方法。千万不要仅依赖GROUP BY排序数据。

4. SELECT子句顺序

表2. SELECT子句及其顺序
子句说明是否必须使用
SELECT要返回的列或表达式
FROM从中检索数据的表仅在从表选择数据时使用
WHERE行级过滤
GROUP BY分组说明仅在按组计算聚集时使用
HAVING组级过滤
ORDER BY输出排序顺序
LIMIT要检索的行数

作者:牧心.
来源链接:https://blog.csdn.net/Aibiabcheng/article/details/118858642

版权声明:
1、JavaClub(https://www.javaclub.cn)以学习交流为目的,由作者投稿、网友推荐和小编整理收藏优秀的IT技术及相关内容,包括但不限于文字、图片、音频、视频、软件、程序等,其均来自互联网,本站不享有版权,版权归原作者所有。

2、本站提供的内容仅用于个人学习、研究或欣赏,以及其他非商业性或非盈利性用途,但同时应遵守著作权法及其他相关法律的规定,不得侵犯相关权利人及本网站的合法权利。
3、本网站内容原作者如不愿意在本网站刊登内容,请及时通知本站(javaclubcn@163.com),我们将第一时间核实后及时予以删除。





本文链接:https://www.javaclub.cn/database/112515.html

标签:group by
分享给朋友:

“【MySQL】分组数据(GROUP BY 和 HAVING)” 的相关文章

数据库之事务及事务的 ACID 性质 2022年05月21日 11:37:16
mysql 查询数据库内存大小 2022年06月06日 11:11:26
MySql查询某一天的数据 2022年06月14日 10:43:20
mysql的查询操作 2022年06月14日 12:38:40
mysql null 优化 2022年06月15日 17:15:21
mysql中查询包含反斜杠字符串 2022年06月17日 23:56:38