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排名函数的更多相关文章

  1. oracle rank()和dense_rank(), row_number() 的区别

    转自:http://www.linuxidc.com/Linux/2015-04/116349.htm 假设现在有一张学生表student,学生表中有姓名.分数.课程编号,现在我需要按照课程对学生的成 ...

  2. 在MySQL中实现Rank高级排名函数【转】

    MySQL中没有Rank排名函数,当我们需要查询排名时,只能使用MySQL数据库中的基本查询语句来查询普通排名.尽管如此,可不要小瞧基础而简单的查询语句,我们可以利用其来达到Rank函数一样的高级排名 ...

  3. 在MySQL中实现Rank高级排名函数

    MySQL中没有Rank排名函数,当我们需要查询排名时,只能使用MySQL数据库中的基本查询语句来查询普通排名.尽管如此,可不要小瞧基础而简单的查询语句,我们可以利用其来达到Rank函数一样的高级排名 ...

  4. MySQL实现SQL Server排名函数

    最近在MySQL中遇到分组排序查询时,突然发现MySQL中没有row_number() over(partition by colname)这样的分组排序.并且由于MySQL中没有类似于SQL Ser ...

  5. Oracle排名函数(Rank)实例详解

    这篇文章主要介绍了Oracle排名函数(Rank)实例详解,需要的朋友可以参考下     --已知:两种排名方式(分区和不分区):使用和不使用partition --两种计算方式(连续,不连续),对应 ...

  6. SQL2005四个排名函数(row_number、rank、dense_rank和ntile)的比较

    排名函数是SQL Server2005新加的功能.在SQL Server2005中有如下四个排名函数: .row_number .rank .dense_rank .ntile 下面分别介绍一下这四个 ...

  7. 好用的排名函数~ROW_NUMBER(),RANK(),DENSE_RANK() 三兄弟

    排名函数三兄弟,一看名字就知道,都是为了排名而生!但是各自有各自的特色!以下一个例子说明问题!(以下栗子没有使用Partition By 的关键字,整个结果集进行排序) RANK 每个值一个排名,同样 ...

  8. 四个排名函数(row_number、rank、dense_rank和ntile)的比较

    排名函数是SQL Server2005新加的功能.在SQL Server2005中有如下四个排名函数: 1.row_number 2.rank 3.dense_rank 4.ntile 下面分别介绍一 ...

  9. Sql 四大排名函数(ROW_NUMBER、RANK、DENSE_RANK、NTILE)简介

    排名函数是Sql Server2005新增的功能,下面简单介绍一下他们各自的用法和区别.我们新建一张Order表并添加一些初始数据方便我们查看效果. CREATE TABLE [dbo].[Order ...

随机推荐

  1. javascript语言精粹:继承

    继承提供了2个有用的任务: 1.代码重用 2.引入了一套类型系统的规范,因为程序员无需编写显示类型转换的代码,他们的工作量将大大减轻.这是一件很好的事情,应为类型转换会丧失类型系统在安全上的优势. 在 ...

  2. ORM框架Hibernate (四) 一对一单向、双向关联映射

    简介 在上一篇博客说了一下多对一映射,这里再说一下一对一关联映射,这种例子在生活中很常见,比如一个人的信息和他的身份证是一对一.又如一夫一妻制等等. 记得在Java编程思想上第一句话是“一切皆对象”, ...

  3. 前端上传组件 - Plupload

    http://www.cnblogs.com/KTblog/p/4740852.html 效果: 起始界面. ------------- 可以上上传单个文件. ------------- 可以上传多个 ...

  4. C++部分术语(Terms)

    翻译自msdn,如有不妥当的地方,欢迎指正. 声明(Declaration):声明引入了一个名字以及其类型进入程序中,并没有定义一个相关的对象或者函数.然而,很多声明都作为定义使用.   定义(def ...

  5. 我的Python成长之路---第二天---Python基础(8)---2016年1月9日(晴)

    数据类型之字典 一.字典简介 字典dict(dictionary),在其他语言中也成为map,使用键-值(key-value)的形式存储和展现,具有极快的查找速度. 字典的定义 d = {'key': ...

  6. 高级UIKit-02(文件操作)

    [day3_1_Sandbox]:沙箱的介绍 snadbox沙箱沙盒 沙箱根目录下的几个文件夹: 1.应用名称.app存放应用程序的素材 2.Documents:存放应用运行时需要用到的数据(关键性数 ...

  7. 利用git下载skia库

    1.准备好cygwin或者gitbash(github下载) 2.进入进入https://android.googlesource.com/,搜索skia,进入. 3.进入后最上面会显示下载方法:gi ...

  8. getComputedStyle与currentStyle

    currentStyle:获取计算后的样式.也叫当前样式.终于样式. 长处:能够获取元素的终于样式.包含浏览器的默认值,而不像style仅仅能获取行间样式.所以更经常使用到. 注意:不能获取复合样式如 ...

  9. 编译kernel:编译

    韦东山Linux视频第1期_裸板_UBoot_文件系统_驱动初步第10课第3节 内核启动流程分析之Makefile.WMV  1. 编译内核分三步: make xxx_defconfig [linux ...

  10. Can't call commit when autocommit=true(转)

    java.sql.SQLException: Can't call commit when autocommit=true at com.mysql.jdbc.SQLError.createSQLEx ...