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助手,依托大模型,帮助用户记录、整理和分析音视频内容,体验用大模型做音视频笔记、整理会议记录。
相关推荐
2301_803875612 小时前
JavaScript 中按字段对嵌套对象数组进行分组的实用教程xuhaoyu_cpp_java2 小时前
连接池学习shark22222222 小时前
Spring 的三种注入方式?qq_372154232 小时前
如何在 WooCommerce 后台按订单总金额精准筛选订单MmeD UCIZ2 小时前
redis连接服务qq_424098562 小时前
CSS如何让背景图片在容器内居中_使用background-position设为centerLucifer三思而后行2 小时前
Vertica 玩转示例数据库:VMartLucifer三思而后行2 小时前
zCloud 纳管 Oracle 数据库m0_617881422 小时前
如何将扁平数组转换为嵌套树形结构(JavaScript 实现)