Oracle分页sql

在Oracle数据库中,分页查询通常涉及到ROWNUM伪列,这是一个Oracle特有的关键字,用于返回结果集中行的编号。以下是几种常见的Oracle分页SQL写法:

1. 使用ROWNUM进行分页查询
复制代码
SELECT * FROM (
    SELECT ROWNUM r, t.* FROM (
        SELECT column1, column2, ... FROM table_name WHERE conditions ORDER BY column_name
    ) t WHERE ROWNUM <= (page * pageSize)
) WHERE r >= ((page - 1) * pageSize + 1)

在这个例子中,page是当前页码,pageSize是每页显示的记录数。这种方法首先使用内部查询获取排序后的结果集,然后通过ROWNUM来限制结果集的大小,最后通过外部查询来获取指定页码的数据。

2. 使用FETCH FIRSTOFFSET子句(Oracle 12c及以上版本)
复制代码
SELECT column1, column2, ...
FROM table_name
WHERE conditions
ORDER BY column_name
OFFSET (page - 1) * pageSize ROWS
FETCH FIRST pageSize ROWS ONLY

这里,OFFSET子句用于指定跳过的记录数,而FETCH FIRST子句用于指定返回的记录数。这种方法提供了一种更简洁、直观的语法来实现分页效果。

3. 使用ROW_NUMBER()窗口函数
复制代码
SELECT * FROM (
    SELECT ROW_NUMBER() OVER(ORDER BY column_name) AS rn, t.*
    FROM table_name
    WHERE conditions
) WHERE rn BETWEEN ((page - 1) * pageSize + 1) AND (page * pageSize)

这种方法通过ROW_NUMBER()窗口函数为结果集中的每一行生成一个唯一的序号,然后根据这个序号来选择指定页码的数据。

4. 使用OFFSETFETCH NEXT(Oracle 12c及以上版本)
复制代码
SELECT column1, column2, ...
FROM table_name
WHERE conditions
ORDER BY column_name
OFFSET (page - 1) * pageSize ROWS
FETCH NEXT pageSize ROWS ONLY

这种方法与使用FETCH FIRST类似,但是它直接指定了要跳过的记录数和要返回的记录数,适用于Oracle 12c及以上版本。

在选择分页查询方法时,应考虑查询的性能和数据库的版本。对于Oracle 12c及以上版本,推荐使用FETCH FIRSTOFFSET子句,因为它们提供了更简洁的语法和良好的性能。对于早期版本的Oracle,使用ROWNUMROW_NUMBER()窗口函数是比较常见的做法。

相关推荐
Teable任意门互动18 分钟前
AI原生开源多维表格有哪些?主流开源多维表格对比解析
数据库·开源·excel·钉钉·飞书·开源软件·ai-native
TDengine (老段)1 小时前
MNode 内部机制深度解析 — SDB、事务引擎与 DDL 处理全链路
大数据·数据库·物联网·时序数据库·iot·tdengine·涛思数据
这个DBA有点耶1 小时前
数据库上云 vs 自建:从成本到人力的三维对比与决策框架
数据库·经验分享·sql·创业创新·dba
shizhan_cloud1 小时前
MySQL 索引优化 + 慢查询日志
数据库·mysql
Drache_long1 小时前
MySQL数据库(故障排除)
数据库·mysql
2303_821287381 小时前
如何清洗SQL输入数据_使用框架内置的ORM处理数据交互
jvm·数据库·python
清风雅雨1 小时前
AI编程:OA流程明细表中多个金额字段由整数改为2位小数
数据库·ai编程
菜鸟上路_lbz1 小时前
sqlserver存储过程查询缓慢锁表分析
数据库·sqlserver
Elastic 中国社区官方博客1 小时前
在 Elasticsearch 中使用利润率与流行度加权来优化电商搜索
大数据·数据库·elasticsearch·搜索引擎·全文检索
van久2 小时前
Day32:项目性能优化(EF Core + 分页 + 全异步)
数据库·oracle·性能优化