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

  • 相关阅读:
    C# 从类库中获取资源图片,把图片资源保存到类库中
    C# Bitmap/png转成jpg格式,压缩图片
    C# 窗体间传值(使用委托与自定义事件)
    C# Image与Base64编码互转函数
    简单Tomcat HTTP RPC框架
    Java 网络IO编程总结(BIO、NIO、AIO均含完整实例代码)
    Java序列化机制和原理
    攻破JAVA NIO技术壁垒
    代理模式(Proxy)
    Java序列化与反序列化
  • 原文地址:https://www.cnblogs.com/happyday56/p/795832.html
Copyright © 2011-2022 走看看