Oracle之分组函数嵌套以及表连接
Posted
tags:
篇首语:本文由小常识网(cha138.com)小编为大家整理,主要介绍了Oracle之分组函数嵌套以及表连接相关的知识,希望对你有一定的参考价值。
--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之分组函数嵌套以及表连接的主要内容,如果未能解决你的问题,请参考以下文章
oracle:数值型函数,日期函数,转换函数,组函数,分组,排序,两表查询连接