oracle的几个排序函数 ROW_NUMBER()/DENSE_RANK()/RANK()
来源:互联网 发布:为什么老是80端口占用 编辑:程序博客网 时间:2024/06/07 19:42
今天看到有位同事的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
- oracle的几个排序函数 ROW_NUMBER()/DENSE_RANK()/RANK()
- Oracle分级排序函数Rank、Dense_Rank、Row_Number比较
- oracle笔记(5)----排序函数row_number、rank、dense_rank
- Oracle的分析函数ROW_NUMBER、DENSE_RANK、RANKOracle的分析函数ROW_NUMBER、DENSE_RANK、RANK
- SQLServer2005增加的排序函数RANK(),DENSE_RANK(),ROW_NUMBER(),NTILE()
- ORACLE-排序技巧ROW_NUM,ROW_NUMBER,RANK,DENSE_RANK,
- 如何使用Oracle的分析函数ROW_NUMBER、DENSE_RANK、RANK
- oracle分析函数row_number、dense_rank、rank的区别
- Oracle分析函数RANK(),DENSE_RANK(),ROW_NUMBER()的用法
- MSSQL 排序函数 ROW_NUMBER() RANK() DENSE_RANK() NTILE()
- 关于函数row_number,rank,dense_rank排序
- ORACLE Rank, Dense_rank, row_number
- 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
- 网络题
- 说说你曾经最拼命地时候吧
- 脸皮需要厚点
- 截屏并保存为bmp格式
- 可靠的消息协议
- oracle的几个排序函数 ROW_NUMBER()/DENSE_RANK()/RANK()
- 从char/wchar_t到TCHAR
- XSLT transform
- jrebel eclipse/tomcat 使用方法-编译后不再需要重启
- 见过网站响应慢的,没见过这么慢的
- Oracle删除重复记录 企业为什么经常使用Oracle?
- Linux Kernel代码分段分析尝试
- 不能再逃避了。。。重拾旧项目
- 常用进制转换方法