COUNT(*)统计每组总行数(含NULL),COUNT(字段)仅统计该字段非NULL的行数;COALESCE可将NULL转为有效值参与计数;WHERE在分组前过滤,HAVING在分组后筛选且只能引用分组字段或聚合函数。GROUP BY 后 COUNT(*) 和 COUNT(字段) 的区别在哪很多人以为 COUNT(*) 和 COUNT(字段) 只差一个括号,实际行为完全不同:前者统计每组行数(含 NULL),后者跳过该字段为 NULL 的行。比如按部门分组统计员工数,若某部门有 5 行记录但其中 2 人的 salary 是 NULL,COUNT(salary) 返回 3,COUNT(*) 返回 5。常见错误现象:SELECT dept, COUNT(salary) FROM emp GROUP BY dept 导致"某部门人数变少",其实是把 NULL 薪资的人直接剔除了,不是漏数据,是逻辑误用。要统计"该组有多少条记录",无条件用 COUNT(*)要统计"该组中某字段非空的个数",才用 COUNT(字段)如果字段本身允许 NULL,又想把它当"0"或"未知"参与计数,得先用 COALESCE 处理用 COALESCE 把 NULL 转成占位值再聚合COALESCE 不是为美化输出而存在,它是让 NULL 进入聚合计算的关键桥梁。比如想统计每个部门里"薪资已知"和"薪资未知"的人数,不能靠 COUNT 直接区分,得构造可计数的标记。使用场景:报表中需要把 NULL 归入某类(如"未填写""待确认"),而不是丢弃它。示例:SELECT dept, COUNT(*) AS total, COUNT(COALESCE(salary, -1)) AS non_null_salary_count, COUNT(*) - COUNT(COALESCE(salary, -1)) AS null_salary_countFROM empGROUP BY dept;注意:COALESCE(salary, -1) 本身不改变 salary 值,只是让 NULL 在 COUNT 中被当作有效值处理(因为 COUNT 只跳过真正的 NULL,不跳过 -1)。这里填 -1 或 'unknown' 都可以,关键是它不能是 NULL。 通义听悟 阿里云通义听悟是聚焦音视频内容的工作学习AI助手,依托大模型,帮助用户记录、整理和分析音视频内容,体验用大模型做音视频笔记、整理会议记录。
相关推荐
南极企鹅9 分钟前
事务&@Transactional注解UrSpecial13 分钟前
Redis与多线程bqq1986102618 分钟前
MySQL 8与MySQL 5.7的主要区别yaoxin52112321 分钟前
406. Java 文件操作基础 - 字符与二进制流阿坤带你走近大数据40 分钟前
Java中的JVM、类加载记住、多线程、性能优化的概念一勺菠萝丶44 分钟前
macOS 安装 Python 包报错:`externally-managed-environment` 怎么解决?chushiyunen1 小时前
r树索引、mysql对r树的支持会编程的土豆1 小时前
Redis Sorted Set(有序集合)详解Xiacqi11 小时前
Java数据库连接--JDBC--DRUIDYushan Bai1 小时前
ORACLE Enterprise Manager Cloud Control 系列测试3-Data Masking