1、where和having都是用来筛选的
2、where是对分组前的结果进行条件过滤,而having是对分组后的结果进行过滤。
3、当分组删选的时候,用having
4、其他用where
注:用having就一定要和group by 连用,而且group by在having的前面
而且having可以跟聚合函数,而where则不能
eg:
要求显示平均工资大于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;
2、where是对分组前的结果进行条件过滤,而having是对分组后的结果进行过滤。
3、当分组删选的时候,用having
4、其他用where
注:用having就一定要和group by 连用,而且group by在having的前面
而且having可以跟聚合函数,而where则不能
eg:
要求显示平均工资大于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;
来自 “ ITPUB博客 ” ,链接:http://blog.itpub.net/29618264/viewspace-1415538/,如需转载,请注明出处,否则将追究法律责任。
转载于:http://blog.itpub.net/29618264/viewspace-1415538/