ORACLE SQL_分页查询

本文介绍了Oracle SQL中使用ROWNUM进行分页查询的方法。通过子查询和ROWNUM伪列结合,实现对数据的分页展示,如每页10条记录,查询第4页的数据。文中强调了ROWNUM只能配合小于或小于等于操作符使用,并提供了相关示例。

摘要生成于 C知道 ,由 DeepSeek-R1 满血版支持, 前往体验 >

                      ORACLE SQL _分页查询

~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~

开发工具与关键技术:Oracle sql * plus  PLSQL Developer

作者:叶

撰写时间:2019年01月01日

~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~

  TOP-N 分析:

ROWNUM 的使用: 因为ROWNUM 是对结果加的一个伪列,即先查询到结果之后再加上去的一个列(强调: 先要有结果集)。

简单的说 ROWNUM 是对符合条件结果的序列号。

它是从1 开始排起的      

说明:ROWNUM “伪列”---数据表本身并没有这样的列,是ORACLE数据库为每个数据表

 “加上的”列。

例如:

          先用子查询查询出姓名,工资,按工资进行降序排序,子查询查出来的结果给到

     主查询查询 再用ROWNUM “伪列”进行重新排序,最后使用WHERE 条件语句筛选。

SELECT LAST_ANME, SALARY FROM (SELECT LAST_NAME, SALARY FROM EMPLOYEES ORDER BY SALARY DESC) WHERE ROWNUM <=10

                            

 

注意: **对ORWNUM 只能使用 < 或<=, 而是用=,>,>= 都将不能返回任何数据。

SELECT * FROM (SELECT ROWNUM RN, EMPLOYEE_ID, SALARY FROM (SELECT EMPLOYEE_ID, SALARY, LAST_NAME FROM EMPLOYEES ORDER BY SALARY DESC) WHERE ROWNUM <=50)

WHERE RN >40

                   

对Oralce 数据库中记录进行分页: 每页显示10条记录,查看第4页的数据。

 

SELECT EMPLOYEE_ID, LAST_NAME, SALARY FROM (SELECT ROWNUM RN, EMPLOYEE_ID, LAST_NAME, SALARY FROM EMPLOYEES) F

WHERE F.RN <=40 AND F.RN > 30;

                

 

注意: **对 oracle 分 页 必须使用 ROWNUM“伪列”。

评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值