介绍一下 Oracle中的 ROWNUM 和 ROW_NUMBER OVER

目录

前言

一、ROWNUM:结果集的行号伪列

[1. 基本特性](#1. 基本特性)

[2. 常用场景:限制返回的行数](#2. 常用场景:限制返回的行数)

[3. 分页的正确写法(结合 ROWNUM)](#3. 分页的正确写法(结合 ROWNUM))

[4. ROWNUM 的局限](#4. ROWNUM 的局限)

[二、OVER 与 ROW_NUMBER():窗口函数中的行号](#二、OVER 与 ROW_NUMBER():窗口函数中的行号)

[1. 基本语法](#1. 基本语法)

[2. 典型例子:各部门按工资排序,从高到低编号](#2. 典型例子:各部门按工资排序,从高到低编号)

[3. 与 ROWNUM 的核心区别](#3. 与 ROWNUM 的核心区别)

三、其它

[OVER 英文 在这里如何解析](#OVER 英文 在这里如何解析)

[PARTITION BY 对应的英文是什么](#PARTITION BY 对应的英文是什么)

[什么叫 分析函数,为什又叫窗口函数](#什么叫 分析函数,为什又叫窗口函数)

[为什么 ,WHERE ROWNUM > 1 永远不会返回任何行](#为什么 ,WHERE ROWNUM > 1 永远不会返回任何行)

[Oracle 中 PARTITION BY 的作用是什么](#Oracle 中 PARTITION BY 的作用是什么)


================

前言

在 Oracle 数据库中,ROWNUMOVER 是用于不同目的但经常被混淆的两个概念。简单来说:

  • ROWNUM 是一个伪列,它在查询结果集返回时,为每一行分配一个唯一的、递增的行号。

  • OVER分析函数(窗口函数) 的一部分,它与 ROW_NUMBER()RANK() 等函数配合,在保留所有原始行的基础上,进行分组、排序和编号。

下面详细拆解这两个概念。

================

一、ROWNUM:结果集的行号伪列

1. 基本特性

  • ROWNUM 是 Oracle 特有的,在查询返回行的过程中动态生成。

  • 第一行 ROWNUM = 1,第二行 ROWNUM = 2,依次类推。

  • 关键点ROWNUM 是在 WHERE 条件过滤之后、ORDER BY 排序之前 分配的。也就是说,如果用了 ORDER BY,排序会改变行的物理顺序,但 ROWNUM 仍然是按照原始获取顺序分配的(除非使用子查询)。

2. 常用场景:限制返回的行数

sql 复制代码
-- 返回前 5 行(不等同于排序后的前 5)
SELECT * FROM employees WHERE ROWNUM <= 5;

注意WHERE ROWNUM > 1 永远不会返回任何行,因为第一行被过滤后,第二行不会变成第一行(ROWNUM 始终从 1 开始)。所以要实现真正的分页,需要嵌套子查询。

3. 分页的正确写法(结合 ROWNUM

sql 复制代码
SELECT * FROM (
    SELECT e.*, ROWNUM rn FROM (
        SELECT * FROM employees ORDER BY salary DESC
    ) e WHERE ROWNUM <= 20
) WHERE rn > 10;

4. ROWNUM 的局限

  • 无法直接实现"每组内排名"。

  • ORDER BY 同时使用时容易出错(因为先分配 ROWNUM 再排序)。

  • 属于 Oracle 特有,不兼容其他数据库(如 PostgreSQL、MySQL 用 LIMIT)。

二、OVERROW_NUMBER():窗口函数中的行号

OVER 是分析函数的子句,用于定义窗口 (即数据分组和排序的范围)。最常用的与行号相关的函数是 ROW_NUMBER()

1. 基本语法

sql 复制代码
ROW_NUMBER() OVER ( [PARTITION BY 列1, 列2...] ORDER BY 列3 [ASC|DESC] )
  • PARTITION BY:可选,将数据分成独立的分组(如部门、类别)。

  • ORDER BY:在每个组内指定排序规则。

  • ROW_NUMBER():为每个组内的行分配一个唯一的、从1开始的连续编号。

=====

2. 典型例子:各部门按工资排序,从高到低编号

sql 复制代码
SELECT 
    employee_id, 
    department_id, 
    salary,
    ROW_NUMBER() OVER (PARTITION BY department_id ORDER BY salary DESC) AS rn
FROM employees;

结果:每个部门内部,工资最高的人 rn=1,次高 rn=2,等等。

===

3. 与 ROWNUM 的核心区别

特性 ROWNUM ROW_NUMBER() OVER
分配时机 WHERE 后、ORDER BY 在整个查询的最后阶段(SELECT 时计算)
分组支持 支持 PARTITION BY 分组内部编号
是否唯一 整个结果集唯一且递增 每个分组内唯一,不同分组编号独立
顺序控制 受限于执行顺序,容易出错 通过 ORDER BY 明确控制
标准兼容 Oracle 专有 SQL:2003 标准,多数数据库支持

====

三、其它

OVER 英文 在这里如何解析

====

PARTITION BY 对应的英文是什么

====

什么叫 分析函数,为什又叫窗口函数

====

为什么 ,WHERE ROWNUM > 1 永远不会返回任何行



====

Oracle 中 PARTITION BY 的作用是什么

====

相关推荐
暴躁小师兄数据学院39 分钟前
【AI大数据工程师特训笔记】第05讲:关联查询
数据库·sql·oracle
倔强的石头_1 小时前
《Kingbase护城河》——跨平台环境下的数据库联调实战
数据库
lzhdim1 小时前
SQL 入门 17:MySQL 数据类型:从字符串到 JSON 的全面解析
数据库·sql·mysql·json
杨云龙UP1 小时前
Oracle RAC / ODA 生产环境指定 PDB 启动 SOP
linux·运维·数据库·oracle
kingwebo'sZone2 小时前
在Cent上安装Mysql 8.0的遇到的问题和解决办法
数据库·mysql·adb
幽络源小助理2 小时前
最新知识付费系统网站源码 PC+H5双端 附安装教程 – 幽络源源码网
大数据·数据库
小白考证进阶中2 小时前
Oracle OCP证书报考&考试全指南
数据库·oracle·oracle ocp·ocp认证·oracle认证·甲骨文认证·oracle ocp题库
Leon-Ning Liu3 小时前
【真实经验分享】 ORA-600 [qesmaGetTblSeg1]
数据库·oracle
与数据交流的路上3 小时前
MySQL 优化 -- 相关
数据库·mysql
Rooting++3 小时前
为什么mysql的表字段的collation会自动变
数据库·mysql