使用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

分类:  Oracle

本文转自快乐就好博客园博客,原文链接:http://www.cnblogs.com/happyday56/archive/2007/06/26/795832.html,如需转载请自行联系原作者
相关文章
|
2天前
|
SQL Oracle 算法
|
4天前
|
SQL Oracle 关系型数据库
Oracle|内置函数之INSTR
【7月更文挑战第5天】
|
4天前
|
Oracle 关系型数据库 数据挖掘
|
2天前
|
Oracle 关系型数据库 数据挖掘
|
28天前
|
存储 Oracle NoSQL
Oracle中decode函数详解
Oracle中decode函数详解
|
8月前
|
算法
Leetcode 313. Super Ugly Number
题目翻译成中文是『超级丑数』,啥叫丑数?丑数就是素因子只有2,3,5的数,7 14 21不是丑数,因为他们都有7这个素数。 这里的超级丑数只是对丑数的一个扩展,超级丑数的素因子不再仅限于2 3 5,而是由题目给定一个素数数组。与朴素丑数算法相比,只是将素因子变了而已,解法还是和朴素丑数一致的。
76 1
|
1月前
|
存储 SQL 算法
LeetCode 题目 65:有效数字(Valid Number)【python】
LeetCode 题目 65:有效数字(Valid Number)【python】
|
2月前
|
存储 算法
【LeetCode力扣】单调栈解决Next Greater Number(下一个更大值)问题
【LeetCode力扣】单调栈解决Next Greater Number(下一个更大值)问题
20 0
|
8月前
|
存储
Leetcode Single Number II (面试题推荐)
给你一个整数数组,每个元素出现了三次,但只有一个元素出现了一次,让你找出这个数,要求线性的时间复杂度,不使用额外空间。
28 0
|
算法
LeetCode 414. Third Maximum Number
给定一个非空数组,返回此数组中第三大的数。如果不存在,则返回数组中最大的数。要求算法时间复杂度必须是O(n)。
75 0
LeetCode 414. Third Maximum Number

推荐镜像

更多