共計(jì) 1222 個(gè)字符,預(yù)計(jì)需要花費(fèi) 4 分鐘才能閱讀完成。
自動(dòng)寫代碼機(jī)器人,免費(fèi)開通
這篇文章主要介紹 Oracle 分頁查詢的示例分析,文中介紹的非常詳細(xì),具有一定的參考價(jià)值,感興趣的小伙伴們一定要看完!
Oracle 分頁查詢的實(shí)例詳解
1.Oracle 分頁查詢:
SELECT * FROM
( SELECT A.*, ROWNUM RN FROM
(SELECT * FROM tab) A
WHERE ROWNUM = 40 )
WHERE RN = 21;
這個(gè)分頁比下面的執(zhí)行時(shí)間少,效率高。
2.
select * from
(select c.*,rownum rn from tab c) where rn between 21 and 40
對(duì)比這兩種寫法,絕大多數(shù)的情況下,第一個(gè)查詢的效率比第二個(gè)高得多。這是由于 CBO 優(yōu)化模式下,Oracle 可以將外層的查詢條件推到內(nèi)層查詢中,以提高內(nèi)層查詢的執(zhí)行效率。對(duì)于第一個(gè)查詢語句,第二層的查詢條件 WHERE ROWNUM = 40 就可以被 Oracle 推入到內(nèi)層查詢中,這樣 Oracle 查詢的結(jié)果一旦超過了 ROWNUM 限制條件,就終止查詢將結(jié)果返回了。
而第二個(gè)查詢語句,由于查詢條件 BETWEEN 21 AND 40 是存在于查詢的第三層,而 Oracle 無法將第三層的查詢條件推到最內(nèi)層(即使推到最內(nèi)層也沒有意義,因?yàn)樽顑?nèi)層查詢不知道 RN 代表什么)。】因此,對(duì)于第二個(gè)查詢語句,
Oracle 最內(nèi)層返回給中間層的是所有滿足條件的數(shù)據(jù),而中間層返回給最外層的也是所有數(shù)據(jù)。數(shù)據(jù)的過濾在最外層完成,
顯然這個(gè)效率要比第一個(gè)查詢低得多。
上面分析的查詢不僅僅是針對(duì)單表的簡單查詢,對(duì)于最內(nèi)層查詢是復(fù)雜的多表聯(lián)合查詢或最內(nèi)層查詢包含排序的情況一樣有效。
3. 下面簡單討論一下多表聯(lián)合的情況。對(duì)于最常見的等值表連接查詢,CBO 一般可能會(huì)采用兩種連接方式
NESTED LOOP 和 HASH JOIN(MERGE JOIN 效率比 HASH JOIN 效率低,一般 CBO 不會(huì)考慮)。
在這里,由于使用了分頁,因此指定了一個(gè)返回的最大記錄數(shù),NESTED LOOP 在返回記錄數(shù)超過最大值時(shí)
可以馬上停止并將結(jié)果返回給中間層,而 HASH JOIN 必須處理完所有結(jié)果集(MERGE JOIN 也是)。
那么在大部分的情況下,對(duì)于 Oracle 分頁查詢選擇 NESTED LOOP 作為查詢的連接方法具有較高的效率
(分頁查詢的時(shí)候絕大部分的情況是查詢前幾頁的數(shù)據(jù),越靠后面的頁數(shù)訪問幾率越小)。
SELECT /*+FIRST_ROWS*/ * FROM ---hint 提示,優(yōu)化查詢
( SELECT A.*, ROWNUM RN FROM
(SELECT * FROM tab) A
WHERE ROWNUM = 400 )
WHERE RN = 380
以上是“Oracle 分頁查詢的示例分析”這篇文章的所有內(nèi)容,感謝各位的閱讀!希望分享的內(nèi)容對(duì)大家有幫助,更多相關(guān)知識(shí),歡迎關(guān)注丸趣 TV 行業(yè)資訊頻道!
向 AI 問一下細(xì)節(jié)