用ROW_NUMBER函数可以解决什么问题

前端之家收集整理的这篇文章主要介绍了用ROW_NUMBER函数可以解决什么问题前端之家小编觉得挺不错的,现在分享给大家,也给大家做个参考。
  • 作用(Purpose)
    用来统计top-n或者bottom-n
    比如你可以用它来统计(或者说查询)出
    a.各个部门工资高的 n个员工
    b.各个部门最先入职的 n个员工
    所以符合这个应用情景条件是:
    a.1对多(部门对员工)
    b.要对多的一方(员工)最高或最低的某个字段(工资,入职时间等)进行统计
    c.前n个

  • 语法(Syntax
    ROW_NUMBER() over(PARTITION BY **A** ORDER BY **B** desc/asc)
    其中:
    A: 1对多中1的那一方
    B: 最高或最低的某个字段

  • 具体实例(Examples)
    各个部门工资高的 3个员工

SELECT department_id,first_name,last_name,salary FROM ( SELECT department_id,salary,ROW_NUMBER() OVER (PARTITION BY department_id ORDER BY salary desc) rn FROM HR.employees ) WHERE rn <= 3 ORDER BY department_id,salary DESC,last_name;

各个部门最先入职的 3个员工

SELECT department_id,HIRE_DATE,ROW_NUMBER() OVER (PARTITION BY DEPARTMENT_ID ORDER BY HIRE_DATE ASC) R FROM HR.employees ) WHERE R <=3 ORDER BY department_id,HIRE_DATE ASC,last_name;

猜你在找的Oracle相关文章