现在的位置: 首页 > 综合 > 正文

oracle-having条件过滤与where条件过滤

2012年07月24日 ⁄ 综合 ⁄ 共 316字 ⁄ 字号 评论关闭

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;

 

抱歉!评论已关闭.