--通用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 

 

 posted on 2017-08-08 16:32  黄小黄的黄  阅读(17839)  评论(0编辑  收藏  举报