HAVING 与 WHERE 类似,可用来决定选择哪个记录。
在使用 GROUP BY对这些记录分组后,HAVING 会决定应显示的记录,
不同的是where对分组前的结果集条件过滤,而having对分组后的结果集过滤;
having何以跟聚合函数,而where则不能。
现在举个例子:
范例:要求显示平均工资大于2000的部门编号和平均工资
Select deptno,avg(sal) from emp where avg(sal)>2000 group by deptno;
出现错误,where语句中不允许使用分组函数,使用having解决
Select deptno,avg(sal) from emp group by deptno having avg(sal)>2000;