- 查询每个部门工资前三名的员工信息
--通用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
- 查找每个人最新的20条信息
SELECT MID,reward,redate FROM t_reward_day r1 WHERE ( SELECT COUNT(1) FROM t_reward_day r2 WHERE r2.mid=r1.mid AND r2.redate>r1.redate )<20 ORDER BY MID,redate