介绍一下 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 的作用是什么

====

相关推荐
六月雨滴1 小时前
Oracle 数据库实例启动与关闭
数据库·oracle·dba
NineData1 小时前
还在轮询 MySQL 吗?用 NineData 把业务变更直接送进 Kafka
数据库·mysql·kafka·ninedata·数据复制·玖章算术·数据迁移工具
gQ85v10Db1 小时前
Redis分布式锁进阶第三十二篇
数据库·redis·分布式
Dovis(誓平步青云)1 小时前
《SQL语义等价性检查:Pivot的CASE WHEN改写策略与限制》
linux·windows·sql·microsoft·oracle·stable diffusion
wmm_会飞的@鱼2 小时前
FlexSim-基于SLP方法的A汽车企业总装车间布局优化
前端·数据结构·数据库·python·数学建模·汽车
北秋,2 小时前
Web Security Academy 第三关:SQL 注入查询 Oracle 数据库版本
数据库·sql·oracle
whn19772 小时前
继续,在centos10上安装pg
数据库
邮专薛之谦2 小时前
MySQL 完整SQL指令大全(仅代码+备注)
数据库·oracle
夕除2 小时前
spring boot 2
数据库