zoukankan      html  css  js  c++  java
  • SQL查询每个部门工资前三名的员工信息

    --通用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 
  • 相关阅读:
    正则匹配
    去除数组、对象某个元素
    换行
    a标签问题
    vue的坑
    宽度100%-20px ,css样式设置超出部分...
    搜狗密码框自带小键盘问题
    阻止button刷新页面
    Java IO流经典练习题
    Java中统计字符串中各个字符出现的次数
  • 原文地址:https://www.cnblogs.com/hxzblog/p/7307537.html
Copyright © 2011-2022 走看看