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;
本文详细解释了SQL中HAVING子句与WHERE子句的区别,包括它们如何对数据进行过滤及何时使用。通过实例展示了在分组查询中,当需要使用聚合函数进行条件判断时,HAVING子句的应用。
4514

被折叠的 条评论
为什么被折叠?



