row_number() rank()跳序 dense_rank()不跳序
前言
????在数据库查询中,我们经常要进行排序,排名,最常用的三个方法莫过于row_number()、rank()、dense_rank()了,而这三个方法又有些相近的地方,会让许多初学者感到混乱,今天我们就来对这三个排序方法进行一个简单的介绍帮助大家在使用前能够更好地理解它们。
准备工作
????我们新建一个数据库,并在该库内新建一个表(姓名,学号,分数),并插入若干条记录,注意为了测试上面三个函数,我们需要设置有重复的分数,到这里准备工作就完毕了。
??字段信息 ??信息记录
张三 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() 排名递增、重复、不跳序;
如果您对文章还有疑问的地方,欢迎在评论区留言评论。
|