oracle分頁語句

2021-09-01 21:53:07 字數 788 閱讀 1002

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多條記錄

個人感覺1的效率最好,3次之,2最差

refurl:

總結:oracle也可以用rownum>a && rownum上面3種不僅都實現了,而且還考慮了效率問題。

oracle 分頁語句

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 r...

Oracle分頁語句

select from select a.rownum rd from select from tablename where condition order by condition a where rownum endpage pagesize where rd startpage pagesi...

Oracle分頁語句

select from select a.rownum r from 這裡的sql可以改成你真正要執行的sql select from articles order by pubtime desc a 用上面的sql得回來的集合,使用rownum去比對,這樣rownum就會從這 個集合的第一筆資料開...