oralce 的分页一共有三种
1. rownum
select * from emp
2. 显示rownum[Oracle 分配的]
select a1.* ,rownum rn from (select * from emp) a1;
3.
4.几个查询的变化
a.指定查询列只需修改最里层的子查询就可以了
b.排序也是只需要修改最里面的就可以了
----------------------------------------------------------
1.按ROWID来分
select * from t-xiaoxi where rowid in (select rid from
(select rownum rn,rid from (select rowid, rid,cid from
t_xiaoxi order by cid desc) where rownum<10000)where
rn>9980) order by cid desc;
执行时间为0.03秒
2.按分析函数来分
select * from (select t.* ,row_number() over(order by cid
desc ) rk from t_xiaoxi t ) where rk<10000 and rk>9980;
执行时间为1.01 秒
3.按ROWNUM 来分
select * from (select t.* ,rownum rn from (select * from
t_xiaoxi order by cid desc ) t where rownum<10000) where
rn>9980 ;
执行时间为0.1秒
其中—t_xiaoxi 为表名,cid为表的关键字段,取按CId降序排序
后的第9981-9999条记录,t_xiaoxi 表中有70000多条记录
本文详细介绍了Oracle的分页技术,包括rownum、显示rownum和使用分析函数的方法,并通过实例展示了每种方法的执行效率,以及如何在查询中应用这些技术。
528

被折叠的 条评论
为什么被折叠?



