oracle 语句分页优化

本文介绍了两种在Oracle数据库中实现分页查询的方法:使用ROWNUM和ROWID。ROWNUM方法通过子查询直接获取所需记录范围;ROWID方法则通过ROWID定位具体记录,据说在大数据量及取中间段数据时相对更快。

一种常用的方法 rownum方法

   select *
  from (select x1.*, rownum r
          from (select x.* from appsys_objects x order by id) x1
         where rownum < 10)
 where r > 5

 

二种rowid 方法

   select *
  from (select rid, r
          from (select rid, rownum r
                  from (select rowid rid from appsys_objects x order by id)
                 where rownum < 10)
         where r > 5) t,
       appsys_objects t1
 where t.rid = t1.rowid

 

据说第二种比第一种在数据量大时、取中间段时相对要快。

评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值