有价值的SQL

本文介绍了如何使用SQL查询每个部门工资前三名的员工信息,包括通用SQL方法和Oracle特有查询方式。通过row_number()函数进行分组排序,实现对每个部门内部工资的排名。此外,还展示了查找每个员工最新20条记录的方法。
摘要由CSDN通过智能技术生成
  • 查询每个部门工资前三名的员工信息
--通用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

 

 

 

 

  • 0
    点赞
  • 0
    收藏
    觉得还不错? 一键收藏
  • 1
    评论
评论 1
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值