使用GROUP BY分组时需配合COUNT函数统计:1、COUNT(*)统计每组总行数(含NULL);2、COUNT(列名)统计该列非NULL值数量;3、COUNT(DISTINCT列名)统计每组内该列唯一值个数;4、Excel/WPS中用GROUPBY函数实现类似计数;5、SQL中加WITH ROLLUP可获分组总计。

如果您在使用 GROUP BY 进行数据分组时,需要统计每组中记录的数量,则需配合 COUNT 聚合函数完成。以下是实现该目标的多种方法:
一、基础语法:COUNT(*) 统计每组总行数
COUNT(*) 会统计每个分组中的所有行,包括含有 NULL 值的行,是 GROUP BY 中最常用的计数方式。它不依赖具体列,仅按分组逻辑计算行数。
1、编写 SELECT 语句,指定分组字段与 COUNT(*) 函数。
2、使用 GROUP BY 子句后接分组字段名(如 department、product_type)。
3、执行查询,结果将显示每个分组值及其对应总行数。
二、COUNT(列名) 统计非 NULL 值数量
COUNT(列名) 仅统计该列中非 NULL 的值个数,适用于需排除空值干扰的场景,例如统计实际填写了“订单金额”的订单数。
1、在 SELECT 中写入 COUNT(指定列),如 COUNT(order_amount)。
2、确保该列名存在于表结构中且参与分组逻辑一致。
3、运行后每组返回的是该列非空单元格的数量,而非整行数。
三、COUNT(DISTINCT 列名) 统计去重后的唯一值数量
当需要知道某组内某一字段有多少个不同取值时,使用 COUNT(DISTINCT 列名) 可直接获得去重计数结果,例如统计每个部门中涉及的不同客户地区数。
1、在 SELECT 中输入 COUNT(DISTINCT 地区字段),如 COUNT(DISTINCT city)。
十天学会易语言图解教程用图解的方式对易语言的使用方法和操作技巧作了生动、系统的讲解。需要的朋友们可以下载看看吧!全书分十章,分十天讲完。 第一章是介绍易语言的安装,以及运行后的界面。同时介绍一个非常简单的小程序,以帮助用户入门学习。最后介绍编程的输入方法,以及一些初学者会遇到的常见问题。第二章将接触一些具体的问题,如怎样编写一个1+2等于几的程序,并了解变量的概念,变量的有效范围,数据类型等知识。其后,您将跟着本书,编写一个自己的MP3播放器,认识窗口、按钮、编辑框三个常用组件。以认识命令及事件子程序。第
2、注意 DISTINCT 后只能跟单个列名或表达式,不可多列组合。
3、执行后每组输出的是该列在本组范围内的唯一值个数。
四、Excel/WPS 中 GROUPBY 函数的 COUNT 应用
在支持 GROUPBY 函数的电子表格软件中,可通过函数形式替代 SQL 实现快速计数汇总,无需编写复杂语句,适合非技术人员操作。
1、在目标单元格输入公式:=GROUPBY(A2:A100,B2:B100,COUNT,3),其中 A 列为分组字段,B 列为待计数区域,COUNT 表示计数方式,3 表示显示标题。
2、若需对多列分别计数,可将第二参数设为多列区域(如 B2:C100),第三参数使用 HSTACK(COUNT,COUNT) 实现并行计数。
3、如需在结果中添加总计行,第五参数设置为 1 或 2 即可启用总计或总计+小计。
五、SQL 中结合 WITH ROLLUP 获取分组总数
WITH ROLLUP 可在常规 GROUP BY 结果末尾追加一行汇总数据,用于快速查看全部记录总数,避免额外执行 COUNT(*) 查询。
1、在 GROUP BY 后添加 WITH ROLLUP 关键字。
2、使用 IFNULL 或 COALESCE 将汇总行中出现的 NULL 分组值替换为文本标识,如 IFNULL(department, '总计')。
3、执行后最后一行为所有分组的合计数量,其分组字段显示为指定标识而非 NULL。









