zoukankan      html  css  js  c++  java
  • 使用Oracle的分析函数ROW_NUMBER、DENSE_RANK、RANK

     

    这三个分析函数都可以在各个分组内从1开始排序。
    ROW_NUMBER()是没有重复值的,可以利用它实现分页显示。
    DENSE_RANK()是连续排序,有两个第二名时仍然跟着第三名。
    RANK()是跳跃排序,有两个第二名时接下来就是第四名(同样是在各个分组内)。

    SELECT * FROM (
         SELECT deptno, ename, sal, ROW_NUMBER()
         OVER (
           PARTITION BY deptno ORDER BY sal DESC
         ) Top3 FROM emp
    )
    WHERE Top3 <= 3

    /

        DEPTNO ENAME                SAL          TOP3
    ---------- ---------- ---------- ----------
               10 KING                   5000             1
               10 CLARK               2450             2
               10 MILLER              1300             3

               20 SCOTT               3000             1
               20 FORD                 3000             2
               20 JONES                2975             3

               30 BLAKE               2850             1
               30 ALLEN               1600             2
               30 TURNER            1500             3

    9 rows selected.

     

    SELECT * FROM (
         SELECT deptno, ename, sal, DENSE_RANK()
         OVER (
           PARTITION BY deptno ORDER BY sal DESC
         ) TopN FROM emp
    )
    WHERE TopN <= 3
    ORDER BY deptno, sal DESC
    /


           DEPTNO ENAME                SAL          TOPN
    ---------- ---------- ---------- ----------
               10 KING                  5000             1
               10 CLARK               2450             2
               10 MILLER              1300             3

           
       20 SCOTT               3000             1     <--- !
              20 FORD                3000             1     <--- !

               20 JONES               2975             2
               20 ADAMS              1100             3

               30 BLAKE               2850             1
               30 ALLEN               1600             2
               30 TURNER            1500             3


    10 rows selected.

     

    SELECT * FROM (
         SELECT deptno, ename, sal, RANK()
         OVER (
           PARTITION BY deptno ORDER BY sal DESC
         ) TopN FROM emp
    )
    WHERE TopN <= 3
    ORDER BY deptno, sal DESC
    /


           DEPTNO ENAME                SAL          TOPN
    ---------- ---------- ---------- ----------
               10 KING                   5000             1
               10 CLARK               2450             2
               10 MILLER              1300             3

           
       20 SCOTT               3000            1     <--- !
              20 FORD                 3000           1     <--- !

               20 JONES               2975            3

               30 BLAKE               2850             1
               30 ALLEN               1600             2
               30 TURNER            1500             3

  • 相关阅读:
    Android 5.0以下系统支持TLS 1.1/1.2协议版本
    Java & Android未捕获异常处理机制
    Oppo Reno2 不允许安装非正式签名应用
    Android ADB 实用总结
    Android Studio中的非项目文件及项目目录下的全局搜索
    Android开发中网络代理设置实用总结
    基于时间偏差思路下的时间周期度量
    nodejs anywhere 搭建本地静态文件服务
    Android 支持库迁移到AndroidX
    项目Gradle版本从4.4升级到4.6
  • 原文地址:https://www.cnblogs.com/happyday56/p/795832.html
Copyright © 2011-2022 走看看