当前位置:   article > 正文

MySQL 三个排序方法 row_number()、rank()、dense_rank()_mysql排序rownumber

mysql排序rownumber



前言

    在数据库查询中,我们经常要进行排序,排名,最常用的三个方法莫过于row_number()、rank()、dense_rank()了,而这三个方法又有些相近的地方,会让许多初学者感到混乱,今天我们就来对这三个排序方法进行一个简单的介绍帮助大家在使用前能够更好地理解它们。


准备工作

    我们新建一个数据库,并在该库内新建一个表(姓名,学号,分数),并插入若干条记录,注意为了测试上面三个函数,我们需要设置有重复的分数,到这里准备工作就完毕了。

  字段信息
  你可以自己设置,不必与示例相同。

类型长度小数点不是null
namevarchar25501
numvarchar25502
scint00
  信息记录
张三	1001	99
李四	1002	96
王五	1003	98
老六	1004	97
赵七	1005	98
黄八	1006	91
  • 1
  • 2
  • 3
  • 4
  • 5
  • 6

实验过程

row_number()

  查询代码

select *,
row_number() over (order by sc desc)
as prior from table_rank;
  • 1
  • 2
  • 3

    row_number()函数是不会跳过重复排名,即如果有两个相同的分数,他会将这两个人作为先后两名顺序依次排出,并且后面一个人的名次是依次顺加的。具体结果请看下方。
  查询结果

张三	1001	99	1
王五	1003	98	2
赵七	1005	98	3
老六	1004	97	4
李四	1002	96	5
黄八	1006	91	6
  • 1
  • 2
  • 3
  • 4
  • 5
  • 6
rank()

  查询代码

select *,
rank() over (order by sc desc)
as prior from table_rank;
  • 1
  • 2
  • 3

    在这里我们简单解释一下查询语句的含义,总体含义就是从table_rank这个表中使用rank()方法对表中的sc字段按照降序进行排列,并给最终得到的排名以prior字段作为排名字段给出。order by sc desc即是按照sc这个字段进行降序排列。
    rank()函数他不会讲分数相同的两个人排出先后,并且会跳排名,跳排名即如果前面两个人分数相同,那么这两个人的排名是相同的,但是,他俩后面的那个人排名会直接跳一名次,如果前面两个并列第三,那么下一个人直接降为第五名而不是第四名,具体结果请看下方。
  查询结果

张三	1001	99	1
王五	1003	98	2
赵七	1005	98	2
老六	1004	97	4
李四	1002	96	5
黄八	1006	91	6
  • 1
  • 2
  • 3
  • 4
  • 5
  • 6
dense_rank()

  查询代码

select *,
dense_rank() over (order by sc desc)
as prior from table_rank;
  • 1
  • 2
  • 3

    dense_rank()可以认为是将前面两个函数的一部分特点结合后的函数,即它进行排序时,既会并列排序,同时也会将后面人的名次顺加,不发生跳序。具体结果请看下方。
  查询结果

张三	1001	99	1
王五	1003	98	2
赵七	1005	98	2
老六	1004	97	3
李四	1002	96	4
黄八	1006	91	5
  • 1
  • 2
  • 3
  • 4
  • 5
  • 6

结论

    通过前面的介绍,当使用这三种不同的排序方法时,我们可以得到以下结论:
    row_number()排名递增、不跳序;
    rank() 排名重复、有跳序;
    dense_rank() 排名递增、重复、不跳序;

如果您对文章还有疑问的地方,欢迎在评论区留言评论。

声明:本文内容由网友自发贡献,不代表【wpsshop博客】立场,版权归原作者所有,本站不承担相应法律责任。如您发现有侵权的内容,请联系我们。转载请注明出处:https://www.wpsshop.cn/w/小丑西瓜9/article/detail/713126
推荐阅读
相关标签
  

闽ICP备14008679号