1. 程式人生 > >mysql和oracle分頁查詢

mysql和oracle分頁查詢

mysql分頁 分頁查詢 使用 pan mysql分頁查詢 nbsp max 記錄 不能

MYSQL分頁查詢

方式1:

select * from table order by id limit m, n; 

  該語句的意思為,查詢m+n條記錄,去掉前m條,返回後n條記錄。無疑該查詢能夠實現分頁功能,但是如果m的值越大,查詢的性能會越低(越後面的頁數,查詢性能越低),因為MySQL同樣需要掃描過m+n條記錄。

方式2:

select * from table where id > #max_id# order by id limit n;

  該查詢每次會返回n條記錄,卻無需像方式1掃描過m條記錄,在大數據量的分頁情況下,性能可以明顯好於方式1,但該分頁查詢必須要每次查詢時拿到上一次查 詢(上一頁)的一個最大id(或最小id)。該查詢的問題就在於,我們有時沒有辦法拿到上一次查詢(上一頁)的最大id(或最小id),比如當前在第3 頁,需要查詢第5頁的數據,該查詢方法便愛莫能助了。

方式3:

  為了避免能夠實現方式2不能實現的查詢,就同樣需要使用到limit m, n子句,為了性能,就需要將m的值盡力的小,比如當前在第3頁,需要查詢第5頁,每頁10條數據,當前第3頁的最大id為#max_id#:

select * from table where id > #max_id# order by id limit 20, 10;

  其實該查詢方式是部分解決了方式2的問題,但如果當前在第2頁,需要查詢第100頁或1000頁,性能仍然會較差。

2、oracle分頁查詢

根據ROWID來分 取500到10000

select * from t_xiaoxi where rowid in(
        select rid from(
                  select rownum rn,rid from(
                   select rowid rid,cid fromt_xiaoxi  order by cid desc) 
             where rownum<10000) 
            where rn>500) 
       order by cid desc;

  

方式2:

  按ROWNUM來分 取500到10000

select * from(
                     select t.*,rownum rn from(
                                        select * from t_xiaoxi order by cid desc) t 
                           where rownum<10000) 
where rn>500

  

mysql和oracle分頁查詢