HAVING语句通常与GROUP BY子句及聚集函数COUNT,AVG,SUM,MAX,MIN语句联合使用,用来过滤由GROUP BY语句返回的记录集,通常跟在GROUP BY后边作用相当于WHERE。
where子句后边是指定行所对应的条件,并且不能含有聚集函数,而HAVING后边是指定组所对应的条件,可以含有聚合函数。HAVING语句的存在弥补了WHERE关键字不能与聚集函数联合使用的不足。 我们可以这样理解:where筛选的是行(一个元组),而having筛选的是组(多行元组)。
GROUP BY子句 : 将查询结果按某一列或多列的值分组,值相等的为一组。如果未对查询结果分组,聚集函数将作用于整个查询结果。分组后聚集函数将作用于每一个组,即每一组都有一个函数值。如果分组后还要求按一定的条件对这些组进行筛选,最终只输出满足指定条件的组,则可以使用 HAVING短语指定筛选条件。 聚合/聚集函数: COUNT(*)统计元组个数 COUNT([ DISTINCTIALL])统计列中值的个数 SUM([ DISTINCT JALLI)计算一列值的总和(此列必须是数值型) AVG( LDISTINCTIALL]k列名>)计算一列值的平均值(此列必须是数值型) MAX([ DISTINCTIALL])求一列值中的最大值 MIN([DSTⅠ NCTIALL])求一列值中的最小值
HAVING使用举例 例一 显示每个地区的总人口数和总面积.仅显示那些面积超过1000000的地区 SELECT region, SUM(population), SUM(area) FROM bbc GROUP BY region HAVING SUM(area)>1000000 例二 查询部门平均薪资高于全体员工薪资的部门名称,及部门平均薪资 SELECT Dname SUM(salary) as 部门平均薪资 FROM department GROUP BY Dname HAVING SUM(area)> (SELECT SUM(salary) FROM department ) 例三 查询班级平均成绩大于75的班级信息。 SELECT Class SUM(grade) FROM department GROUP BY Class HAVING SUM(grade)> 75
含有HAVING子句的SQL语句执行顺序如下: (1)where子句查找符合条件的数据; (2)使用group by 子句对数据进行分组; (3)对每个分组运行聚集函数计算; (4)用having 子句去掉不符合条件的组。 注: having 子句中的元素必须出现在select列表中。 ------------------------------------------------------完-------------------------------------------------