--通用sql
1 select deptno, ename, sal 2 from emp e1 3 where 4 ( 5 select count(1) 6 from emp e2 7 where e2.deptno=e1.deptno and e2.sal>=e1.sal 8 ) <=3 /*这里的数值表示你想取前几名*/ 9 order by deptno, sal desc;
--oracle查询
1 select * from 2 (select deptno,ename,sal,row_number() over (partition by deptno 3 order by sal desc) rn 4 from emp) 5 where rn<3;
row_number() OVER (PARTITION BY COL1 ORDER BY COL2) 表示根据COL1分组,在分组内部根据 COL2排序,而此函数计算的值就表示每组内部排序后的顺序编号(组内连续的唯一的) 与rownum的区别在于:使用rownum进行排序的时候是先对结果集加入伪列rownum然后再进行排序,而此函数在包含排序从句后是先排序再计算行号码. row_number()和rownum差不多,功能更强一点(可以在各个分组内从1开时排序). rank()是跳跃排序,有两个第二名时接下来就是第四名(同样是在各个分组内). dense_rank()l是连续排序,有两个第二名时仍然跟着第三名。相比之下row_number是没有重复值的 查询每个部门的最高工资 select deptno,ename,sal from (select deptno,ename,sal,row_number() over (partition by deptno order by sal desc) as sal_order from scott.emp) where sal_order <2