跨表统计需先明确主表(结果分组依据)与从表(提供聚合字段),再据空值需求选JOIN类型;如统计各部门员工数及平均薪资,应以dept为主表LEFT JOIN emp,GROUP BY主表非聚合字段,并注意COUNT与AVG对NULL的处理差异。

跨表统计的核心不是堆函数,而是理清表间关系再选连接方式。先确认主表、从表,再看统计维度落在哪张表,最后决定用 JOIN 还是子查询——多数场景 JOIN 更直观高效。
比如要统计“每个部门的员工数和平均薪资”,部门信息在 dept 表,员工信息在 emp 表,那 dept 就是主表(结果要按部门展示),emp 是从表(提供人数、薪资数据)。不能反过来以 emp 为主表再 group by dept_id,否则没员工的部门会被漏掉。
继续上面的例子:如果用 INNER JOIN,部门没员工就不出现在结果里;用 LEFT JOIN,空部门也会显示 0 人、NULL 平均薪资。实际写法:
SELECT d.name, COUNT(e.id) AS emp_cnt, ROUND(AVG(e.salary), 2) AS avg_sal
FROM dept d
LEFT JOIN emp e ON d.id = e.dept_id
GROUP BY d.id, d.name;
再进阶:查“每个城市中,2023年入职且薪资超8000的员工所在部门的平均薪资”。涉及 city(来自 dept)、emp 入职时间、薪资、部门平均薪资——四层逻辑:
推荐分步写:先写带 WHERE 的基础 JOIN 查出目标员工+部门+城市,再套一层 GROUP BY city, dept_id,外层再聚合。比单条嵌套三层子查询更易调试。
常见坑:
基本上就这些。跨表统计不复杂但容易忽略连接语义和空值处理,动手前花两分钟画个表关系草图,比查十次语法更快。
以上就是SQL跨表统计怎么写_真实案例解析强化复杂查询思维【教学】的详细内容,更多请关注php中文网其它相关文章!
每个人都需要一台速度更快、更稳定的 PC。随着时间的推移,垃圾文件、旧注册表数据和不必要的后台进程会占用资源并降低性能。幸运的是,许多工具可以让 Windows 保持平稳运行。
Copyright 2014-2025 https://www.php.cn/ All Rights Reserved | php.cn | 湘ICP备2023035733号