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

Oracle之分组函数嵌套以及表连接

时间:2017-05-12 00:20:26      阅读:390      评论:0      收藏:0      [点我收藏+]

标签:style   group   group by   环境   left join   sel   表连接   avg   dna   

--1 数据环境准备

scott 用户下面的emp,dept表

--2 要求 :求平均工资最高的部门编号,部门名称,部门平均工资

select d.deptno,d.dname,e.sal
from(
select avg(sal) sal,deptno
from emp e
group by deptno
having avg(sal) = (select max(avg(sal)) from emp group by deptno))e
left join dept d
on e.deptno=d.deptno;

有人说,红色加粗的一段多此一举,红色部分完全可以写成如下形式

select max(avg(sal)) sal,deptno
from emp e
group by deptno;

但是注意,分组函数可以嵌套使用,但是在组函数嵌套使用的时候不能再出现分组条件的列名。所以这条语句会直接报错

也就是说,这里用了嵌套分组函数之后,deptno就不能出现列上。

那有人说,我这有写

select max(avg(sal)) sal
from emp e
group by deptno;

这样是不再报错,但是作为关联条件的deptno就没有了。

所以对于有嵌套分组函数的,并且用到表连接的,可以多写一个子查询,子查询里面放的就是嵌套分组函数。

Oracle之分组函数嵌套以及表连接

标签:style   group   group by   环境   left join   sel   表连接   avg   dna   

原文地址:http://www.cnblogs.com/88893636-xuyang/p/6843336.html

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