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分组函数之ROLLUP

oracle:数值型函数,日期函数,转换函数,组函数,分组,排序,两表查询连接

Oracle分组函数之CUBE

Oracle入门第三天(上)——多表查询与分组函数

Java学习总结(十六)——MySQL数据库(中)分组,嵌套,连接查询及外键与关系表设计

sql中根据表中一个字段分组分别统计每个分组的记录数