概述
- WHERE 用于分组前,对普通行进行行过滤,因此不能使用聚合值
- HAVING 用于分组后,对分组字段的分组行进行行过滤,因此可以使用聚合值
疑问
先上结论:HAVING
中可以使用 SELECT
中的字段别名
一个疑问:
按照 SQL
的执行顺序,
GROUP BY
对进行WHERE 行过滤的表格进行分组,
然后HAVING
对分组后的表格进行行过滤,
接着进行 SELECT
列选择,
问题是 HAVING
为什么能使用 SELECT
中的别名?
SELECT m.s_id, AVG(IFNULL(m.s_score, 0)) avg_score
FROM
(
SELECT st.s_id,
sc.s_score
FROM Student st
LEFT JOIN Score sc
ON st.s_id = sc.s_id
) m
GROUP BY m.s_id
-- HAVING AVG(IFNULL(m.s_score, 0)) < 60
HAVING avg_score < 60 # why this also OK ?