SQL统计分组内的所有数据唯一值_使用DISTINCT汇总

COUNT(DISTINCT)在GROUP BY中统计每组唯一值个数,新版主流数据库支持,老版MySQL需用子查询去重后计数;多字段DISTINCT统计组合唯一性,非分别去重;性能差时宜用近似函数或预汇总。GROUP BY 后想统计每组里 DISTINCT 值个数,别直接套 COUNT(DISTINCT ...)MySQL 5.7+、PostgreSQL、SQL Server 2017+ 和 Oracle 都支持 COUNT(DISTINCT column) 在聚合查询中直接使用,但老版本 MySQL(如 5.6)不支持,会报错 ERROR 1111 (HY000): Invalid use of group function。不是语法写错了,是引擎限制。实操建议:先确认你的数据库版本:SELECT VERSION();,再决定能否用 COUNT(DISTINCT ...)如果不能用,得绕路:对分组字段和目标字段做联合去重,再外层计数,比如:SELECT group_col, COUNT(*) AS distinct_cntFROM (SELECT DISTINCT group_col, target_col FROM tbl) tGROUP BY group_col;注意子查询里必须包含所有 GROUP BY 字段,否则外层 GROUP BY 会出错或结果不准想列出每组的所有唯一值(不止个数),STRING_AGG 或 GROUP_CONCAT 更合适单纯统计数量只是第一步;很多时候你需要看到具体有哪些值------比如"每个部门有哪些职级""每类商品用了哪些标签"。这时 COUNT(DISTINCT ...) 就不够用了。实操建议:PostgreSQL 用 STRING_AGG(DISTINCT col, ', '),DISTINCT 关键字必须紧贴字段名,不能写成 STRING_AGG(col, ', ') DISTINCTMySQL 用 GROUP_CONCAT(DISTINCT col SEPARATOR ', '),注意默认长度限制是 1024,超长会被截断,需提前设 SET SESSION group_concat_max_len = 1000000;SQLite 没有原生 DISTINCT 支持,得用子查询先去重再拼接:GROUP_CONCAT(val) FROM (SELECT DISTINCT group_id, val FROM t)DISTINCT 在多字段组合统计时,行为容易被误解写 COUNT(DISTINCT a, b) 看似是"统计 a 和 b 的组合唯一数",但实际就是统计 (a,b) 这一对值的去重数量。不是分别对 a 和 b 去重再相加,也不是取并集。 跃问 跃问是由阶跃星辰开发的免费AI智能问答助手,随时帮你智能搜索、高效阅读、识图理解、和你畅聊感兴趣的话题。

相关推荐
JohnYan7 分钟前
工作笔记 - PG分组极值
数据库·后端·postgresql
清溪5499 分钟前
DataEase H2 JDBC-RCE(CVE-2025-32966)复现
数据库·安全
ServBay18 分钟前
不要再盲选了,PostgreSQL、MySQL与SQLite真实性能对比
数据库·mysql·sqlite
Trouvaille ~19 分钟前
【Redis篇】Set 与 Zset:集合运算与排行榜的终极武器
数据库·redis·缓存·set·跳表·后端开发·zset
無限進步D20 分钟前
MySQL 创建和管理表
数据库·mysql
六月雨滴33 分钟前
归档模式配置与切换
数据库·oracle·dba
卡次卡次11 小时前
vibecoding起步注意点:插件、Skills、MCP、Hooks
服务器·数据库·python·oracle
Elastic 中国社区官方博客1 小时前
每次操作一个 API 调用:Elastic Cloud Hosted 如何让大规模部署管理变得可行
大数据·运维·数据库·elasticsearch·搜索引擎·serverless
清溪5491 小时前
pgAdmin4 <= 9.1_RCE(CVE-2025-2945)复现
数据库·后端
我的xiaodoujiao1 小时前
API 接口自动化测试详细图文教程学习系列24--如何用Pytest去设计接口测试用例并执行
python·学习·测试工具·pytest