news 2026/6/29 17:45:25

SQL分析函数`ROW_NUMBER`的兼容性与深度解析

作者头像

张小明

前端开发工程师

1.2k 24
文章封面图
SQL分析函数`ROW_NUMBER`的兼容性与深度解析

🔍 SQL分析函数ROW_NUMBER()深度解析

ROW_NUMBER()是一个标准的窗口函数 (Window Function),它为分区(partition)或结果集中的每一行分配一个唯一的、连续的序号,从1开始。

1. 语法结构

其基本语法与其他窗口函数类似:

ROW_NUMBER()OVER([PARTITIONBYexpression_list]ORDERBYorder_expression[ASC|DESC],...)
部分说明
ROW_NUMBER()函数名。
OVER必需的子句,指定窗口定义。
PARTITION BY可选。定义行被分组的分区。ROW_NUMBER()会在每个分区内独立编号,并从1重新开始。
ORDER BY必需。指定在每个分区内(或整个结果集内)进行编号时的排序顺序。这是ROW_NUMBER()工作的核心。

核心特性:

  • 唯一且连续:它为每一行生成一个唯一的序号。
  • 非确定性 (Ties):ORDER BY表达式的值相同时(即存在并列/ties),ROW_NUMBER()随机分配不同的、连续的序号。它不会像RANK()DENSE_RANK()那样将相同的值分配相同的序号。

2. 兼容性 (Compatibility)

ROW_NUMBER()SQL:2003 标准中引入的窗口函数的一部分。因此,它在几乎所有主流的现代关系型数据库管理系统 (RDBMS) 中都得到了完美且稳定的支持

数据库系统兼容性备注
Oracle完全支持从 8i 版本开始支持窗口函数。
SQL Server完全支持从 2005 版本开始支持窗口函数。
PostgreSQL完全支持从 8.4 版本开始支持窗口函数。
MySQL完全支持从 8.0 版本开始支持窗口函数。 8.0 之前需要使用变量模拟。
IBM Db2完全支持标准支持。
Teradata完全支持标准支持。
SQLite部分支持较新的版本(如 3.25.0+)通过实现窗口函数而支持。

总结:在绝大多数企业级和现代数据库环境中,您可以放心地使用ROW_NUMBER()函数。

3. 常见应用场景

ROW_NUMBER()是数据分析和数据清洗中最常用的工具之一。

A. 分页查询 (Pagination)

在不支持LIMIT/OFFSET或需要跨数据库兼容时,它常用于实现高效的分页。

SELECT*FROM(SELECT*,ROW_NUMBER()OVER(ORDERBYorder_column)asrnFROMyour_table)ASsubqueryWHERErnBETWEEN11AND20;-- 获取第2页数据(每页10条)
B. 去重/查找每个分组的第一行 (De-duplication / Top-N per Group)

这是ROW_NUMBER()最强大的应用。例如,找出每个员工的最新订单或每个部门工资最高的员工。

假设我们想找出每个部门 (Department) 工资最高的员工。

SELECTemployee_name,department,salaryFROM(SELECTemployee_name,department,salary,ROW_NUMBER()OVER(PARTITIONBYdepartmentORDERBYsalaryDESC)asrank_numFROMemployees_table)ASranked_employeesWHERErank_num=1;-- 过滤出每个部门中排序号为1的行
C. 生成主键/临时ID

在ETL流程中,当需要为临时表或目标表生成一个连续的唯一ID时,可以使用它。

SELECTROW_NUMBER()OVER(ORDERBYsome_column)asunique_id,column1,column2FROMsource_table;

4. 与其他排序函数比较

理解ROW_NUMBER()最好的方式是将其与另外两个排序函数RANK()DENSE_RANK()进行对比。

函数特性并列 (Ties) 行为序号示例 (值: 10, 20,20, 30)
ROW_NUMBER()唯一连续序号。随机分配不同的序号。1, 2, 3, 4
RANK()并列值分配相同序号,跳过下一个序号。相同值分配相同序号。1, 2, 2, 4(跳过3)
DENSE_RANK()并列值分配相同序号,不跳过下一个序号。相同值分配相同序号。1, 2, 2, 3(不跳过)

💡 总结与建议

  • 使用场景:当你需要严格唯一的连续编号,或需要从每个分组中精确地选择第一行(如最新记录、最高值)时,请使用ROW_NUMBER()
  • 排序:即使你的目标不是排序,使用ROW_NUMBER()时也必须包含ORDER BY子句,因为它是基于排序来分配序号的。
  • 注意事项:如果ORDER BY字段存在并列情况,ROW_NUMBER()分配的序号是非确定性的。如果需要确保每次运行的结果完全一致,请在ORDER BY子句中添加一个唯一字段(如主键)来打破并列。
版权声明: 本文来自互联网用户投稿,该文观点仅代表作者本人,不代表本站立场。本站仅提供信息存储空间服务,不拥有所有权,不承担相关法律责任。如若内容造成侵权/违法违规/事实不符,请联系邮箱:809451989@qq.com进行投诉反馈,一经查实,立即删除!
网站建设 2026/6/29 23:44:46

SolidWorks异形孔向导功能介绍

SolidWorks 的 异形孔向导(Hole Wizard)​ 是其最核心的特征工具之一,主要用于快速创建符合国际标准(如 ISO、ANSI、GB 等)的标准化孔特征(如螺纹孔、沉头孔、锥孔、阶梯孔等)。它通过参数化设计…

作者头像 李华
网站建设 2026/6/29 21:27:43

数据大国的存储短板:600亿HDD依赖如何突围?

“HDD(机械硬盘),是我们IT产业链里唯一还没拿下的核心件。”华为高级副总裁、华为云CEO兼数据存储产品线总裁周跃峰的这番言论,近期在存储行业引发广泛共鸣。在AI扩容、云上增算成为行业热点的当下,这个看似“老掉牙”的存储设备,突然成为悬在中国存储产业头顶的“达摩克…

作者头像 李华
网站建设 2026/6/29 19:44:50

零延迟英雄锁定:League Akari智能选人系统深度解析

还在为手慢抢不到心仪英雄而懊恼?每次选人阶段都像在和时间赛跑?League Akari的智能选人系统正是为解决这一痛点而生。在/src/main/modules/auto-select/中的核心算法,能够在毫秒级内完成英雄锁定,让你在选人阶段占据绝对优势。 【…

作者头像 李华
网站建设 2026/6/28 12:31:30

哔哩下载姬:5个实用技巧让你的B站视频下载效率翻倍

哔哩下载姬:5个实用技巧让你的B站视频下载效率翻倍 【免费下载链接】downkyi 哔哩下载姬downkyi,哔哩哔哩网站视频下载工具,支持批量下载,支持8K、HDR、杜比视界,提供工具箱(音视频提取、去水印等&#xff…

作者头像 李华
网站建设 2026/6/26 20:14:09

腾讯优图实验室开源Youtu-Embedding文本表示模型,赋能企业级AI应用创新

10月14日,腾讯优图实验室宣布正式对外发布Youtu-Embedding文本表示模型的源代码。作为一款专为企业级应用场景打造的通用型文本处理工具,该模型凭借其卓越的语义理解能力和广泛的场景适配性,正在成为企业数字化转型进程中的关键技术支撑。据腾…

作者头像 李华