Oracle 分页的三种情况

2014-11-24 18:24:05 · 作者: · 浏览: 1

Oralce 的分页一共有三种


1. rownum


select * from emp


select a1.* ,rownum rn from (select * from emp) a1;


3.几个查询的变化


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多条记录