oracle 11g默认数据库里面,有张emp表,其中有字段ename、deptno、sal分别对应雇员名、部门编号和月薪

大概示意如下,其他字段不用管了,与我的问题无关,差不多就这样的表。

我刚学习了用函数group取出每个部门的最高薪水
select deptno,max(sal) from emp group by deptno;

但是怎么select出每个部门里面月薪最高的雇员呢?。
group by不知道算不算函数,max肯定是函数,如表述有误还请见谅!

第1个回答  推荐于2016-10-27
select deptno,max(sal) from emp group by deptno;
这条语句可以得出每个部门的最高工资,可以在这条语句的基础上和emp表关联,得出月薪最高的雇员;
例如:
select a.ename,a.deptno,a.sal from emp a,(select deptno,max(sal) m_sal from emp group by deptno) b where a.deptno=b.deptno and a.sal=b.m_sql;
除此以外可以是通过分析函数获得部门最高月薪员工
例如:
select ename,deptno,sal,rank() over(partition by deptno order by sal desc) from emp;本回答被提问者采纳

相关了解……

你可能感兴趣的内容

本站内容来自于网友发表,不代表本站立场,仅表示其个人看法,不对其真实性、正确性、有效性作任何的担保
相关事宜请发邮件给我们
© 非常风气网