如何使用Oracle的分析函数ROW_NUMBER、DENSE_RANK、RANK
来源:互联网 发布:机器人编程课程 编辑:程序博客网 时间:2024/04/30 04:42
共同点:这三个分析函数都可以在各个分组内从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
9 rows selected
- 如何使用Oracle的分析函数ROW_NUMBER、DENSE_RANK、RANK
- Oracle的分析函数ROW_NUMBER、DENSE_RANK、RANKOracle的分析函数ROW_NUMBER、DENSE_RANK、RANK
- Oracle:分析函数2(Rank, Dense_rank, row_number)
- oracle分析函数(rank(),dense_rank(),row_number())
- oracle分析函数Rank, Dense_rank, row_number
- oracle 分析函数Rank, Dense_rank, row_number
- oracle分析函数Rank, Dense_rank, row_number
- oracle分析函数Rank, Dense_rank, row_number
- oracle分析函数Rank, Dense_rank, row_number
- ORACLE分析函数(3)---rank,dense_rank,row_number
- oracle 分析函数 RANK、DENSE_RANK、ROW_NUMBER
- oracle分析函数Rank, Dense_rank, row_number
- oracle分析函数Rank, Dense_rank, row_number
- oracle分析函数Rank, Dense_rank, row_number
- oracle分析函数Rank, Dense_rank, row_number
- oracle分析函数Rank, Dense_rank, row_number
- oracle分析函数row_number、dense_rank、rank的区别
- Oracle分析函数RANK(),DENSE_RANK(),ROW_NUMBER()的用法
- C#连接数据库及数据绑定
- .NET(C#)连接各类数据库-集锦
- 软件工程师不可不知的10个概念
- 这么大了还不知道做什么好
- 永不放弃
- 如何使用Oracle的分析函数ROW_NUMBER、DENSE_RANK、RANK
- C#命名规范
- 一表十万地址,另一表四十五万地址,分析地址相似度,并作关联
- Jboss Seam研究之旅
- input type="image"
- 否反对
- pc-lint
- emacs编译
- AnkhSVN - Subversion SCC Provider