Oracle分頁技術詳解

來源:互聯網
上載者:User

 

分頁查詢語句:

         Select * from (

                   Select A.*,rownum rn from (

select * from table table_name )A

where rownum <=40) Where rn>=20;

         最內層的查詢Select * from table_name 表示不進行翻頁的原始查詢語句。Rownu<=40和rn>=21 控制分頁查詢的每頁範圍。

         分頁的目的就是控制輸出結果集大小,將結果儘快的返回,在查詢的最外層控制最小值。而另一種方式是去掉查詢第二層的where ronum <= 40語句,在查詢的最外層控制分頁的最值和最大值,這是,查詢語句如下:

         Select * from ( select A.* ,rownum ru from ( select * from table_name) A ) where ru between 21 and 40

         對比這兩種寫法,絕大數的情況下,第一個查詢的效率比第二個高得多。

         這是由於CBO最佳化模式下,Oracle可以將外層的查詢條件推到內層查詢中,以提高內層查詢的執行效率。對於第一個查詢語句,第二層的查詢條件where rownum<=40 就可以被Oracle推入到內層查詢中,這樣Oracle查詢的結果一旦超過了Rownum限制條件,就將終止查詢結果返回。

           而第二查詢語句,由於查詢條件between 21 and 40 是存在與查詢的第三層,而Oracle無法將第三層的查詢條件推進到最內層(即使推進到最內層也沒有意義,因為最內層查詢不知道rn代表什麼)。因此,對於第二個查詢語句,Oracle最內層返回給中層的是所有滿足條件的資料,而中介層返回給最外層也是所有的資料。資料的過慮在最外層完成,顯然這個效率要比第一個查詢低得多!

         上面的分析的查詢不僅僅是對單表的簡單查詢,還是最內層查詢是複雜得多表聯集查詢後最內層查詢包含排列的情況一樣有效。

聯繫我們

該頁面正文內容均來源於網絡整理,並不代表阿里雲官方的觀點,該頁面所提到的產品和服務也與阿里云無關,如果該頁面內容對您造成了困擾,歡迎寫郵件給我們,收到郵件我們將在5個工作日內處理。

如果您發現本社區中有涉嫌抄襲的內容,歡迎發送郵件至: info-contact@alibabacloud.com 進行舉報並提供相關證據,工作人員會在 5 個工作天內聯絡您,一經查實,本站將立刻刪除涉嫌侵權內容。

A Free Trial That Lets You Build Big!

Start building with 50+ products and up to 12 months usage for Elastic Compute Service

  • Sales Support

    1 on 1 presale consultation

  • After-Sales Support

    24/7 Technical Support 6 Free Tickets per Quarter Faster Response

  • Alibaba Cloud offers highly flexible support services tailored to meet your exact needs.