mysql 查询排名,包括并列排名和连续排名

在MySQL中,根据不同的需求,查询排名可以分为并列排名和连续排名两种情况。

以下是分别实现这两种排名的方法,考虑到兼容性,这里会提供适合较早版本MySQL(即8.0之前版本)的解决方案,同时也提及MySQL 8.0及以上版本的新特性。

示例:查询学生成绩排名

假设有一个scores表,包含学生的student_id和他们的score:

sql 复制代码
CREATE TABLE scores (
    student_id INT,
    score DECIMAL(4,2)
);

INSERT INTO scores VALUES
(1, 95.00),
(2, 90.00),
(3, 95.00),
(4, 85.00),
(5, 78.00);

1、在MySQL(即8.0之前版本)中,由于不支持RANK()或DENSE_RANK()这类窗口函数,所以在早期版本中实现查询排名通常需要借助用户变量。

1.1、并列排名

对于并列排名,即分数相同的学生共享同一个排名,可以使用用户变量来实现。

以下是一个示例:

sql 复制代码
SET @rank := 0;
SET @prev_score := NULL;

SELECT
    student_id,
    score,
    @rank := IF(@prev_score = score, @rank, @rank + 1) AS rank,
    @prev_score := score
FROM
    scores
ORDER BY
    score DESC;

在这个例子中,当分数与前一个分数相同时,排名(@rank)保持不变,从而实现了并列排名。

1.2、连续排名

连续排名是指即使有并列,每个学生的排名都是唯一的,不跳过任何排名数字。

这可以通过稍微修改上面的查询来实现:

sql 复制代码
SET @rank := 0;
SET @prev_score := NULL;
SET @rank_count := 1;

SELECT
    student_id,
    score,
    @rank := @rank + (@prev_score = score) * @rank_count AS rank,
    @prev_score := score,
    @rank_count := IF(@prev_score = score, @rank_count + 1, 1) 
FROM
    scores
ORDER BY
    score DESC;

在这里,增加了一个新的变量@rank_count来跟踪连续排名中的并列次数,每当遇到相同的分数时,@rank_count递增,这样即使分数相同,每个学生的排名也是连续的。

2、MySQL 8.0及以上版本

从MySQL 8.0开始,可以直接使用窗口函数来更简洁地实现这两种排名:

2.1、并列排名:使用RANK()函数

sql 复制代码
  SELECT
      student_id,
      score,
      RANK() OVER (ORDER BY score DESC) AS rank
  FROM
      scores;

2.2、连续排名:使用DENSE_RANK()函数

sql 复制代码
  SELECT
      student_id,
      score,
      DENSE_RANK() OVER (ORDER BY score DESC) AS rank
  FROM
      scores;

RANK()会在遇到相同分数时产生跳过的排名,而DENSE_RANK()则不会跳过,直接给出连续的排名。

相关推荐
SelectDB技术团队13 分钟前
Apache Doris 2025 Roadmap:构建 GenAI 时代实时高效统一的数据底座
大数据·数据库·数据仓库·人工智能·ai·数据分析·湖仓一体
冷凝女子13 分钟前
【QT】获取文件路径中的文件名,去掉后缀,然后提取文件名中的数字
开发语言·数据库·qt
Y第五个季节16 分钟前
Redis - HyperLogLog
数据库·redis·缓存
Allen Bright37 分钟前
【MySQL基础-20】MySQL条件函数全面解析:提升查询逻辑的利器
数据库·mysql
Justice link1 小时前
企业级NoSql数据库Redis集群
数据库·redis·缓存
爱的叹息1 小时前
主流数据库的存储引擎/存储机制的详细对比分析,涵盖关系型数据库、NoSQL数据库和分布式数据库
数据库·分布式·nosql
XiaoLeisj2 小时前
【MyBatis】深入解析 MyBatis XML 开发:增删改查操作和方法命名规范、@Param 重命名参数、XML 返回自增主键方法
xml·java·数据库·spring boot·sql·intellij-idea·mybatis
dleei2 小时前
MySql安装及SQL语句
数据库·后端·mysql
信徒_3 小时前
Mysql 在什么样的情况下会产生死锁?
android·数据库·mysql
嘴对嘴编程4 小时前
oracle数据泵操作
数据库·oracle