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



前言

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


准备工作

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

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

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

实验过程

row_number()

  查询代码

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

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

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

  查询代码

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

    在这里我们简单解释一下查询语句的含义,总体含义就是从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
dense_rank()

  查询代码

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

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

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

结论

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

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

  • 7
    点赞
  • 19
    收藏
    觉得还不错? 一键收藏
  • 1
    评论

“相关推荐”对你有帮助么?

  • 非常没帮助
  • 没帮助
  • 一般
  • 有帮助
  • 非常有帮助
提交
评论 1
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值