oracle的几个排序函数 ROW_NUMBER()/DENSE_RANK()/RANK()

今天看到有位同事的sql中使用了“RANK() over partition BY order by  ”的语句,以前自己没使用过,

将百度结果也一并保存下来以备忘。



sql 原文:

SELECT *
  FROM
  (SELECT BC.SECUCODE 债券代码,
               BC.CHINAME 债券名称,
               TO_CHAR(BC.LISTEDDATE, 'yyyy-mm-dd') 债券上市日期,
               BC.ISSUER 发行人,
               RANK() over(partition BY BC.ISSUER order by BC.LISTEDDATE DESC) RANK_NO
      FROM
      (SELECT DISTINCT JBC.MAINCODE,
                    JBC.CHINAME,
                    JBC.ISSUER,
                    JBC.SECUCODE SECUCODE,
                    JBC.LISTEDDATE LISTEDDATE
            FROM ABC.BOND_CODE JBC
            WHERE TRIM(JBC.ISSUER) NOT IN
                 (SELECT DISTINCT TRIM(JLS.CHINAME)
                    FROM JUYUAN.LC_STOCKARCHIVES JLS)
      ) BC
   )
WHERE rank_no <= 3







百度查询资料:



oracle的几个排序函数



ref url:http://blog.csdn.net/lky5387/archive/2009/12/09/4972512.aspx



rank 根据order by排名 会出现并列排名。下一个值会跳过并列值 比如 1 2 2 4 5
通常对应rank还有 desc_rank 出现并列排名以后,下一个值不跳过并列值 1 2 2 3 4
row_number 就是直接排出一个名次。不会出现并列排名 1 2 3 4 5


这三个分析函数都可以在各个分组内从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

猜你喜欢

转载自lucklysmile-gmail-com.iteye.com/blog/2192838