Mysql 的HAVING子句中COUNT(a)的统计范围

问题是这样的

1.对于a、b两个字段,需要按照a进行分组(Group by a),要返回分组后count(a)>1的a和b两个字段,一条sql解决?

2.如果以及Group by a,b,多个字段 HAVING count(a)>1是怎么统计count(a)的数据的?

在使用GROUP BY语句时,HAVING子句中的COUNT(a)函数是针对每个由GROUP BY指定的字段组合进行统计的。在问题中,GROUP BY a, b意味着结果将根据ab字段的组合进行分组。因此,HAVING COUNT(a) > 1实际上是针对每个唯一的ab组合进行计数

如果数据中有两行如下:

a = 1, b = A
a = 1, b = B

并且执行以下查询:

SELECT a, b
FROM xxx_table
GROUP BY a, b
HAVING COUNT(a) > 1;

在这种情况下,由于ab的每个组合都是唯一的,COUNT(a)对于每个组合都将是1。因此,没有任何组合会满足HAVING COUNT(a) > 1的条件,结果将是空集。

如果您想要根据a字段的值对数据进行分组,而不考虑b字段,您应该只在GROUP BY子句中包含a,然后使用HAVING子句来筛选计数:

SELECT a, COUNT(a) as count_a
FROM your_table
GROUP BY a
HAVING COUNT(a) > 1;

这个查询将返回那些a字段的值出现超过一次的所有a的值及其出现的次数。如果您还想返回b字段的值,您需要考虑如何处理多个b值的情况,因为每个a可能对应多个b。您可以使用聚合函数(如GROUP_CONCAT())来列出所有相关的b值,例如:

SELECT a, GROUP_CONCAT(b) as b_values
FROM your_table
GROUP BY a
HAVING COUNT(a) > 1;

这个查询将返回每个a值及其对应的所有b值的列表(以逗号分隔)。

结论

Group by a,b,多个字段 HAVING count(a)>1是针对每个唯一的ab组合进行计数

相关推荐
tatasix36 分钟前
MySQL UPDATE语句执行链路解析
数据库·mysql
南城花随雪。1 小时前
硬盘(HDD)与固态硬盘(SSD)详细解读
数据库
儿时可乖了1 小时前
使用 Java 操作 SQLite 数据库
java·数据库·sqlite
懒是一种态度1 小时前
Golang 调用 mongodb 的函数
数据库·mongodb·golang
天海华兮1 小时前
mysql 去重 补全 取出重复 变量 函数 和存储过程
数据库·mysql
gma9992 小时前
Etcd 框架
数据库·etcd
爱吃青椒不爱吃西红柿‍️2 小时前
华为ASP与CSP是什么?
服务器·前端·数据库
Yz98762 小时前
hive的存储格式
大数据·数据库·数据仓库·hive·hadoop·数据库开发
武子康3 小时前
大数据-230 离线数仓 - ODS层的构建 Hive处理 UDF 与 SerDe 处理 与 当前总结
java·大数据·数据仓库·hive·hadoop·sql·hdfs
武子康3 小时前
大数据-231 离线数仓 - DWS 层、ADS 层的创建 Hive 执行脚本
java·大数据·数据仓库·hive·hadoop·mysql