HAVING
子句和 WHERE
子句非常相似,HAVING
子句支持 WHERE
子句中所有的操作符和语法,但是两者存在几点差异:
WHERE
子句主要用于过滤数据行,而HAVING
子句主要用于过滤分组,即HAVING
子句基于分组的聚合值而不是特定行的值来过滤数据,主要用来过滤分组。WHERE
子句不可以包含聚合函数,HAVING
子句中的条件可以包含聚合函数。HAVING
子句是在数据分组后进行过滤,WHERE
子句会在数据分组前进行过滤。WHERE
子句排除的行不包含在分组中,可能会影响HAVING
子句基于这些值过滤掉的分组。