IT数码 购物 网址 头条 软件 日历 阅读 图书馆
TxT小说阅读器
↓语音阅读,小说下载,古典文学↓
图片批量下载器
↓批量下载图片,美女图库↓
图片自动播放器
↓图片自动播放器↓
一键清除垃圾
↓轻轻一点,清除系统垃圾↓
开发: C++知识库 Java知识库 JavaScript Python PHP知识库 人工智能 区块链 大数据 移动开发 嵌入式 开发工具 数据结构与算法 开发测试 游戏开发 网络协议 系统运维
教程: HTML教程 CSS教程 JavaScript教程 Go语言教程 JQuery教程 VUE教程 VUE3教程 Bootstrap教程 SQL数据库教程 C语言教程 C++教程 Java教程 Python教程 Python3教程 C#教程
数码: 电脑 笔记本 显卡 显示器 固态硬盘 硬盘 耳机 手机 iphone vivo oppo 小米 华为 单反 装机 图拉丁
 
   -> 大数据 -> MySQL 三个排序方法 row_number()、rank()、dense_rank() -> 正文阅读

[大数据]MySQL 三个排序方法 row_number()、rank()、dense_rank()

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() 排名递增、重复、不跳序;

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

  大数据 最新文章
实现Kafka至少消费一次
亚马逊云科技:还在苦于ETL?Zero ETL的时代
初探MapReduce
【SpringBoot框架篇】32.基于注解+redis实现
Elasticsearch:如何减少 Elasticsearch 集
Go redis操作
Redis面试题
专题五 Redis高并发场景
基于GBase8s和Calcite的多数据源查询
Redis——底层数据结构原理
上一篇文章      下一篇文章      查看所有文章
加:2022-03-13 21:52:47  更:2022-03-13 21:53:21 
 
开发: C++知识库 Java知识库 JavaScript Python PHP知识库 人工智能 区块链 大数据 移动开发 嵌入式 开发工具 数据结构与算法 开发测试 游戏开发 网络协议 系统运维
教程: HTML教程 CSS教程 JavaScript教程 Go语言教程 JQuery教程 VUE教程 VUE3教程 Bootstrap教程 SQL数据库教程 C语言教程 C++教程 Java教程 Python教程 Python3教程 C#教程
数码: 电脑 笔记本 显卡 显示器 固态硬盘 硬盘 耳机 手机 iphone vivo oppo 小米 华为 单反 装机 图拉丁

360图书馆 购物 三丰科技 阅读网 日历 万年历 2025年1日历 -2025/1/16 18:01:20-

图片自动播放器
↓图片自动播放器↓
TxT小说阅读器
↓语音阅读,小说下载,古典文学↓
一键清除垃圾
↓轻轻一点,清除系统垃圾↓
图片批量下载器
↓批量下载图片,美女图库↓
  网站联系: qq:121756557 email:121756557@qq.com  IT数码