Oracle rank和dense_rank排名函数
来源:互联网 发布:centos的iso文件 编辑:程序博客网 时间:2024/05/16 08:47
1.rank函数
rank计算一组值的排名,返回数字类型。排名可能是不连续。如果有5人,其中有2个人排名第一,则rank返回的排名结果为:1 1 3 4 5。
- 作为一个聚合函数,返回虚拟行在样表中的排名。
- 作为一个解析函数,返回每一个的排名。
1.1聚合函数语法
1.2解析函数语法
1.3聚合函数的例子
计算假定薪水为2000的员工在样表中的排名。
SQL> select rank(2000) within group(order by e.sal desc) "Rank"
2 from emp e;
Rank
----------
7
假定薪水为2000的员工,按照薪水从高到低在样表中排第7名。
1.4解析函数的例子
按照薪水从高到低进行排名:
SQL> select e.ename, e.sal, rank() over(order by e.sal desc) "Rank" from emp e;
ENAME SAL Rank
---------- --------- ----------
KING 5000.00 1
FORD 3000.00 2
SCOTT 3000.00 2
JONES 2975.00 4
BLAKE 2850.00 5
CLARK 2450.00 6
ALLEN 1600.00 7
TURNER 1500.00 8
MILLER 1300.00 9
WARD 1250.00 10
MARTIN 1250.00 10
ADAMS 1100.00 12
JAMES 950.00 13
SMITH 800.00 14
薪水为3000重复,并列排名第2,跳过第3.
在部内进行薪水从高到低的排名:
SQL> select e.ename,
2 e.sal,
3 e.deptno,
4 rank() over(partition by e.deptno order by e.sal desc) "Rank"
5 from emp e;
ENAME SAL DEPTNO Rank
---------- --------- ------ ----------
KING 5000.00 10 1
CLARK 2450.00 10 2
MILLER 1300.00 10 3
SCOTT 3000.00 20 1
FORD 3000.00 20 1
JONES 2975.00 20 3
ADAMS 1100.00 20 4
SMITH 800.00 20 5
BLAKE 2850.00 30 1
ALLEN 1600.00 30 2
TURNER 1500.00 30 3
MARTIN 1250.00 30 4
WARD 1250.00 30 4
JAMES 950.00 30 6
2.dense_rank函数
dense_rank计算一组值的排名,该排名是连续整数从1开始。如果有5人,其中有2个人排名第一,则rank返回的排名结果为:1 1 2 3 4。
- 作为一个聚合函数,返回虚拟行在样表中的排名。
- 作为一个解析函数,返回每一个的排名。
2.1聚合函数语法
2.2解析函数语法
2.3聚合函数的例子
计算假定薪水为2000的员工在样表中的排名。
SQL> select dense_rank(2000) within group(order by e.sal desc) "Rank"
2 from emp e;
Rank
----------
6
假定薪水为2000的员工,按照薪水从高到低在样表中排第7名。
2.4解析函数的例子
按照薪水从高到低进行排名:
SQL> select e.ename,
2 e.sal,
3 dense_rank() over(order by e.sal desc) "Rank"
4 from emp e;
ENAME SAL Rank
---------- --------- ----------
KING 5000.00 1
FORD 3000.00 2
SCOTT 3000.00 2
JONES 2975.00 3
BLAKE 2850.00 4
CLARK 2450.00 5
ALLEN 1600.00 6
TURNER 1500.00 7
MILLER 1300.00 8
WARD 1250.00 9
MARTIN 1250.00 9
ADAMS 1100.00 10
JAMES 950.00 11
SMITH 800.00 12
有两个1250并列排名第8,接着1100是第9。排名是连续是连续的。
在部内进行薪水从高到低的排名:
SQL> select e.ename,
2 e.sal,
3 e.deptno,
4 dense_rank() over(partition by e.deptno order by e.sal desc) "Rank"
5 from emp e;
ENAME SAL DEPTNO Rank
---------- --------- ------ ----------
KING 5000.00 10 1
CLARK 2450.00 10 2
MILLER 1300.00 10 3
SCOTT 3000.00 20 1
FORD 3000.00 20 1
JONES 2975.00 20 2
ADAMS 1100.00 20 3
SMITH 800.00 20 4
BLAKE 2850.00 30 1
ALLEN 1600.00 30 2
TURNER 1500.00 30 3
MARTIN 1250.00 30 4
WARD 1250.00 30 4
JAMES 950.00 30 5
20部门有两个3000并列排名第一,接着2975是第二。排名是连续是连续的。
- Oracle rank和dense_rank排名函数
- Oracle rank和dense_rank排名函数
- Oracle问题——排名函数(rank与dense_rank)
- sql server 排名函数 row_number,rank,dense_rank和ntile
- 排名函数(ROW_NUMBER、RANK、DENSE_RANK)及OVER子句 Oracle 中分析函数用法之--rank(),dense_rank(),partition,over()
- 排名分析函数 rank(),dense_rank(),row_number()
- sql 排名函数 rank() , row_number() , dense_rank() over
- SQLSERVER排名函数RANK,DENSE_RANK,NTILE,ROW_NUMBER
- oracle中聚合函数RANK和dense_rank的使用
- Oracle聚合函数RANK和dense_rank的使用
- oracle中聚合函数rank和dense_rank取科目前三名
- oracle中聚合函数RANK和dense_rank的使用
- 有关oracle中聚合函数rank和dense_rank的使用
- oracle中聚合函数rank、dense_rank和row_rumber的使用
- Oracle聚合函数RANK和dense_rank的使用
- Oracle分析函数之Rank()和DENSE_RANK()详解
- Oracle-分析函数之排序值rank()和dense_rank()
- oracle排名函数rank()
- 关于“中度硬核”的概念及其联想
- 算法导论学习笔记
- 给创始人的建议:需要避免的常见创业陷阱
- nodejs系列之七——nodejs与mongoDB
- 一种根据URL参数条件动态生成URL的方法
- Oracle rank和dense_rank排名函数
- MyEclipse 6.5 Blue Edition - Milestone 1版本获取注册码
- JavaScript笔记
- C#通过多线程为基于 .NET 的应用程序实现响应迅速的用户
- poj3080Blue Jeans(在m个串中找到这m个串的 最长连续公共子序列)
- 我治大学生抄作业毛病的办法——兼答丁又专老师
- h264和x264的区别
- DB2与Oracle相关的东东
- SQL遞歸查詢實戰