MySQL8 排名窗口函数实战

 更新时间:2026年02月13日 08:23:56   作者:hpp  
本文阐明SQL三个排名函数处理并列名次时的区别,包括RANK()跳跃,DENSE_RANK()连续,ROW_NUMBER()分配唯一序号,下面就来详细的介绍一下,感兴趣的可以了解一下

在数据库查询与数据分析中,对数据分组并进行排名是一项常见任务。SQL 窗口函数为此提供了高效的解决方案。本文旨在阐明三个核心排名函数——RANK()DENSE_RANK()ROW_NUMBER()——的功能、差异及适用场景。

示例数据模型

以下说明将基于一张students表示例,该表记录了学生的班级与分数。其中,'A'班存在分数相同的学生,这有助于展示各函数的关键区别。

-- 表结构与数据
create table students
(
    id    int auto_increment primary key,
    name  varchar(50) not null,
    class varchar(10) null,
    score int         null
);

INSERT INTO students (name, class, score) VALUES
('甲', 'A', 85),
('乙', 'A', 90),
('丙', 'B', 95),
('丁', 'B', 80),
('张三', 'A', 90);

1.RANK(): 标准排名 (非连续)

RANK() 函数提供标准的排名功能。当存在数值相等的行时,这些行将获得相同的排名,但后续名次的序号将会跳跃。

查询语句:

select name, class, score, rank() over (partition by class order by score desc) as class_rank
from students;

结果:

nameclassscoreclass_rank
A901
张三A901
A853
B951
B802

分析: 在 'A' 班中,'乙' 和 '张三' 因分数相同而并列第 1。随后的 '甲' 的排名为第 3,序列跳过了第 2 名。

2.DENSE_RANK(): 紧凑排名 (连续)

DENSE_RANK() 函数在处理并列排名时,不会在名次序列中产生间隙,确保排名是连续的。

查询语句:

select name, class, score, dense_rank() over (partition by class order by score desc) as class_rank
from students;

结果:

nameclassscoreclass_rank
A901
张三A901
A852
B951
B802

分析: 在 'A' 班中,'乙' 和 '张三' 并列第 1 后,'甲' 的排名为第 2,名次序列保持了连续性。

3.ROW_NUMBER(): 行号分配 (唯一)

ROW_NUMBER() 函数不考虑数值的并列情况,它为分区内的每一行分配一个从 1 开始的、唯一的、连续的整数。

查询语句:

select name, class, score, row_number() over (partition by class order by score desc) as class_rank
from students;

结果:

nameclassscoreclass_rank
A901
张三A902
A853
B951
B802

分析: 即使 '乙' 和 '张三' 的分数相同,ROW_NUMBER() 依然为它们分配了 1 和 2 两个不同的序号。

功能对比与应用场景

函数并列处理排名是否连续主要应用场景
RANK()排名相同不连续 (跳跃)体育赛事等传统排名
DENSE_RANK()排名相同连续 (无间隙)榜单排名,要求名次紧凑
ROW_NUMBER()无并列排名连续分组获取 Top N 记录,数据去重

在实际应用中,应根据排名是否需要处理并列以及名次序列是否需要连续来选择合适的函数。

到此这篇关于MySQL8 排名窗口函数实战的文章就介绍到这了,更多相关MySQL8 排名窗口函数内容请搜索脚本之家以前的文章或继续浏览下面的相关文章希望大家以后多多支持脚本之家!

您可能感兴趣的文章:

相关文章

  • Mysql数据库双机热备难点分析

    Mysql数据库双机热备难点分析

    本文主要给大家介绍了在Mysql数据库双机热备其中的难点分析以及重要环节的经验心得,需要的朋友收藏分享下吧。
    2017-12-12
  • MySQL绿色版设置编码以及1067错误详解

    MySQL绿色版设置编码以及1067错误详解

    这篇文章主要介绍了MySQL绿色版设置编码,以及1067错误的相关资料,需要的朋友可以参考下
    2017-05-05
  • MySQL常见的存储引擎和区别说明

    MySQL常见的存储引擎和区别说明

    MySQL支持多种存储引擎,如InnoDB、MyISAM、MEMORY、Archive、CSV和Blackhole,每种引擎有其特点和适用场景,选择存储引擎时需根据业务需求考虑事务、性能、存储成本等因素
    2025-03-03
  • mysql中向表中某字段追加字符串的方法

    mysql中向表中某字段追加字符串的方法

    mysql中向表中某字段追加字符串的方法...
    2007-03-03
  • MySQL连接控制插件介绍

    MySQL连接控制插件介绍

    当连接数据库失败次数过多时,MySQL 是否会限制登录呢?数据库服务端应该怎么应对暴力破解呢?本篇文章介绍下 MySQL 中的连接控制插件,一起来学习下此插件的作用,需要的朋友可以参考下面文章内容
    2021-09-09
  • MySQL表数据文件损坏导致数据库无法启动的原因与解决方案

    MySQL表数据文件损坏导致数据库无法启动的原因与解决方案

    在日常的数据库管理中,遇到MySQL表数据文件损坏的情况并不罕见,这种情况下,MySQL数据库可能会无法正常启动,给业务运行带来严重影响,本文将探讨如何诊断和解决MySQL表数据文件损坏导致的数据库无法启动问题,需要的朋友可以参考下
    2025-03-03
  • MySQL系统库之performance_schema的实现

    MySQL系统库之performance_schema的实现

    performance_schema用于收集和存储关于数据库性能和资源利用情况的信息,本文主要介绍了MySQL系统库之performance_schema的实现,具有一定的参考价值,感兴趣的可以了解一下
    2023-11-11
  • MySql 设置表格字段key中的值

    MySql 设置表格字段key中的值

    本文主要介绍了MySql 设置表格字段key中的值,文中通过示例代码介绍的非常详细,对大家的学习或者工作具有一定的参考学习价值,需要的朋友们下面随着小编来一起学习学习吧
    2024-05-05
  • MySql安装与卸载的详细教程

    MySql安装与卸载的详细教程

    这篇文章主要为大家介绍了MySql安装与卸载的详细教程,具有一定的参考价值,感兴趣的小伙伴们可以参考一下
    2017-07-07
  • mysql之如何查找配置文件my.ini的位置

    mysql之如何查找配置文件my.ini的位置

    这篇文章主要介绍了mysql之如何查找配置文件my.ini的位置问题,具有很好的参考价值,希望对大家有所帮助。如有错误或未考虑完全的地方,望不吝赐教
    2023-07-07

最新评论