码迷,mamicode.com
首页 > 数据库 > 详细

Oracle的查询-分组查询

时间:2019-08-28 22:36:41      阅读:140      评论:0      收藏:0      [点我收藏+]

标签:pre   查询   工资   font   rac   HERE   条件   sele   dep   

--查询出每个部门的平均工资
select e.deptno,avg(e.sal)
from emp e
group by e.deptno;

分组查询中,出现在 group by 后面的原始列,才能出现在 select 后面

没有出现在 group by 后面的原始列 ,想在 select 后边出现必须加上聚合函数


 

 

--查询出平均工资高于2000的部门
select e.deptno,avg(e.sal)
from emp e
group by e.deptno
having avg(e.sal)>2000;

所有条件都不能使用别名来判断

 

where 是过滤分组前的数据,having 是过滤分组后的数据

where 必须在 group by 之前,having 在 group by 之后


 

 

--查询出每个部门工资高于800的员工的平均工资
--然后再查询出平均工资高于2000的部门
select e.deptno,avg(e.sal)
from emp e
where e.sal>800
group by e.deptno
having avg(e.sal)>2000;

 

Oracle的查询-分组查询

标签:pre   查询   工资   font   rac   HERE   条件   sele   dep   

原文地址:https://www.cnblogs.com/Sm1lence/p/11426755.html

(0)
(0)
   
举报
评论 一句话评论(0
登录后才能评论!
© 2014 mamicode.com 版权所有  联系我们:gaon5@hotmail.com
迷上了代码!