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助手,依托大模型,帮助用户记录、整理和分析音视频内容,体验用大模型做音视频笔记、整理会议记录。
相关推荐
小九九的爸爸3 小时前
前端想要入门Agent开发,要具备哪些Python基础?阿耶同学4 小时前
手把手教你用 LangGraph 搭建三层嵌套 Agent 架构jiayou645 小时前
KingbaseES 表级与列级加密完全指南花酒锄作田20 小时前
Pydantic校验配置文件hboot20 小时前
AI工程师第四课 - 深度学习入门GBASE1 天前
G术时刻 |GBase 8s数据库事务并发控制之封锁技术介绍(下)ZhengEnCi1 天前
P2M-Matplotlib折线图完全指南-从数据可视化到趋势分析的Python绘图利器ZhengEnCi1 天前
P2L-Matplotlib饼图完全指南-从数据可视化到图表定制的Python绘图利器曲幽1 天前
你的REST接口还在“过度投喂”数据吗?——FastAPI + GraphQL实战避坑指南用户8358086187911 天前
基于 Self-RAG 与列表级重排序的进阶 RAG 系统设计与实现