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组合进行计数

相关推荐
胚芽鞘68124 分钟前
关于java项目中maven的理解
java·数据库·maven
nbsaas-boot1 小时前
Java 正则表达式白皮书:语法详解、工程实践与常用表达式库
开发语言·python·mysql
sun0077004 小时前
mysql索引底层原理
数据库·mysql
程序员秘密基地4 小时前
基于html,css,vue,vscode,idea,,java,springboot,mysql数据库,在线旅游,景点管理系统
java·spring boot·mysql·spring·web3
workflower6 小时前
MDSE和敏捷开发相互矛盾之处:方法论本质的冲突
数据库·软件工程·敏捷流程·极限编程
叁沐6 小时前
MySQL 11 怎么给字符串字段加索引?
mysql
Tony小周7 小时前
实现一个点击输入框可以弹出的数字软键盘控件 qt 5.12
开发语言·数据库·qt
lifallen7 小时前
Paimon 原子提交实现
java·大数据·数据结构·数据库·后端·算法
TDengine (老段)7 小时前
TDengine 数据库建模最佳实践
大数据·数据库·物联网·时序数据库·tdengine·涛思数据
Elastic 中国社区官方博客7 小时前
Elasticsearch 字符串包含子字符串:高级查询技巧
大数据·数据库·elasticsearch·搜索引擎·全文检索·lucene