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

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

语法:

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

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

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

sql 复制代码
-- 创建学生成绩表
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:分组排名(部门内排名)

sql 复制代码
-- 创建销售数据表
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 Category
        ORDER BY Sales DESC
    ) AS CategoryRank
FROM ProductSales;

何时使用RANK()?

  • 需要反映自然名次间隔

    例如:奥运会奖牌排名(两个金牌后,下一名是铜牌)

  • 允许并列但保留原始名次逻辑

    例如:考试排名(两人并列第1,下一人直接第3名)

相关推荐
海南java第二人15 小时前
Nebula Graph 实战:基于图数据库存储 CMDB 实体关系
数据库·图数据库·nebula
曹牧15 小时前
oracle:“not all variables bound”
数据库·oracle
数据库百宝箱16 小时前
Oracle RMAN Image Copy 本地恢复
数据库·oracle
zuYM4g7Dp17 小时前
NoSql数据库设计心得
数据库·nosql
睡不醒男孩03082318 小时前
第七篇:揭秘 PostgreSQL 数据库内核级管控:CLup 深度架构设计与高可用底座技术白皮书
数据库·postgresql·clup
cmes_love19 小时前
Level 2逐笔成交历史数据下载方法笔记
数据库·笔记·oracle
swordbob19 小时前
MySQL字符集陷阱:从Oracle迁移踩坑到utf8mb4强制规范
数据库·sql
牛油果子哥q20 小时前
【C++ STL string 】C++ STL string 终极精讲:底层原理、内存机制、全套API、深浅拷贝、易错坑点与工程实战规范
数据库·c++
十五年专注C++开发20 小时前
MySql中各种功能用sql语句实现总结
数据库·sql·mysql
数据库小学妹20 小时前
AI时代数据库怎么选?多模融合、数据统一存储与选型实战指南
数据库·人工智能·经验分享·ai