SQL Server中RANK()函数:处理并列排名与自然跳号

server/2025/2/6 16:17:34/

  RANK()是SQL Server的窗口函数,为结果集中的行生成排名。当出现相同值时,后续排名会跳过被占用的名次,形成自然间隔。与DENSE_RANK()的关键区别在于是否允许排名值连续

       语法:

RANK() OVER ([PARTITION BY 分组列]ORDER BY 排序列 [ASC|DESC]
)
  • PARTITION BY:按指定列分组后分别计算排名

  • ORDER BY:决定排名的排序规则 

        例子1:基础排名(自然跳号)

-- 创建学生成绩表
CREATE TABLE ExamScores (Student NVARCHAR(50),Score INT
);INSERT INTO ExamScores VALUES
('张三', 95),
('李四', 88),
('王五', 95),
('赵六', 80);-- 使用RANK()按分数降序排名
SELECT Student,Score,RANK() OVER (ORDER BY Score DESC) AS Rank
FROM ExamScores;

        结果:

       可以看到rank那一列没有“2”,因为前边有两个“1”,这就是rank函数,会跳过2。

       示例2:分组排名(部门内排名)

-- 创建销售数据表
CREATE TABLE ProductSales (Category NVARCHAR(50),Product NVARCHAR(50),Sales INT
);INSERT INTO ProductSales VALUES
('电子产品', '手机', 1200),
('电子产品', '耳机', 800),
('服装', 'T恤', 600),
('服装', '外套', 600);-- 按商品类别分组,组内按销量排名
SELECT Category,Product,Sales,RANK() OVER (PARTITION BY CategoryORDER BY Sales DESC) AS CategoryRank
FROM ProductSales;

何时使用RANK()?

  • 需要反映自然名次间隔
    例如:奥运会奖牌排名(两个金牌后,下一名是铜牌)

  • 允许并列但保留原始名次逻辑
    例如:考试排名(两人并列第1,下一人直接第3名)


http://www.ppmy.cn/server/165452.html

相关文章

Java三十天速成(java进阶篇)

Day 15 一、集合框架 1、集合框架图 2、数据结构: ①、逻辑结构; 在计算机科学中,逻辑结构是指数据元素之间的关系,它描述了数据元素之间的逻辑联系,而不是它们在计算机内存中的物理存储方式。逻辑结构可以分为以下…

Baklib引领内容中台与人工智能技术的创新融合之路

内容概要 在数字化转型的浪潮中,各行业正在面临前所未有的挑战与机遇。内容中台作为一种新的概念,逐渐进入了企业的视野,它不仅是一个技术平台,更是提供了整合和管理内容的新思路。从根本上,内容中台旨在提升企业对信…

安全漏洞扫描与修复系统的高质量技术详解

安全漏洞扫描与修复系统的高质量技术详解 在当今数字化时代,网络安全已成为企业运营和个人隐私保护的重中之重。安全漏洞扫描与修复系统作为网络安全防护的关键环节,扮演着“哨兵”的角色,通过全面检测与及时修复,筑牢软件安全的…

Unity 2D实战小游戏开发跳跳鸟 - 记录显示最高分

上一篇文章中我们实现了游戏的开始界面,在开始界面中有一个最高分数的UI,本文将接着实现记录最高分数以及在开始界面中显示最高分数的功能。 添加跳跳鸟死亡事件 要记录最高分,则需要在跳跳鸟死亡时去进行判断当前的分数是否是最高分,如果是最高分则进行记录,如果低于之前…

Joplin 插件在Vscode中无法显示图片

1.问题 在vscode里面装好joplin插件之后,无法显示图片内容。 粘贴的图片可以再vscode中显示,无法再joplin客户端显示 2.解决方法 这种情况是因为和vscode自带的MD编辑器的预览模式有冲突,或者没用通过专用方式上传图片。 方法一&#xff…

C语言:深入了解指针2(超详细)

1. 指针跟数组相关的知识 在 C 语言里,数组名在大多数表达式中会隐式转换为指向数组首元素的指针。不过,数组名和指针并不完全等同。 1.数组就是数组,是一块连续的空间,是可以存放一个或者多个数组的。 2.指针变量是一个变量&am…

项目练习:重写若依后端报错cannot be cast to com.xxx.model.LoginUser

文章目录 一、情景说明二、解决办法 一、情景说明 在重写若依后端服务的过程中 使用了Redis存放LoginUser对象数据 那么,有存就有取 在取值的时候,报错 二、解决办法 方法1、在TokenService中修改如下 getLoginUser 方法中:LoginUser u…

DS图(中)(19)

文章目录 前言一、图的遍历广度优先遍历深度优先遍历 二、最小生成树Kruskal算法Prim算法两种方法对比 总结 前言 承上启下,我们来学习下图的中篇!!! 一、图的遍历 图的遍历指的是遍历图中的顶点,主要有 广度优先遍历 …