關(guān)于子查詢非嵌套

Filter/子查詢非嵌套 知識點:

Subquery Unnesting(子查詢非嵌套):

如果SQL語句中的where條件后面有子查詢,子查詢前面有in,not in,exists,not exists,<,<=,=,&get;,&get;= 等等,

CBO很可能會對該子查詢進(jìn)行等價改寫,改寫的過程其實就叫做子查詢擴(kuò)展。Oracle始終認(rèn)為SQL語句進(jìn)行改寫之后,

CBO能更好的優(yōu)化,當(dāng)然了,并不是所有的子查詢都會被改寫,子查詢中有些限制條件會阻止CBO進(jìn)行改寫(因為改寫之后不等價)。

說白了就是?將半連接與反連接的子查詢語句轉(zhuǎn)化成普通的連接,如果沒有子查詢非嵌套化,執(zhí)行的基本的方法就是基于FILTER操作.

這是一個類似于nested loop的一種方法,和nest loop不同之處是要維護(hù)一個hash table 且filter的性能實際上跟列值distinct數(shù)有關(guān),

oracle執(zhí)行時實際上做了很大優(yōu)化,最壞情況下才會出現(xiàn)對外表每一行 執(zhí)行一次filter操作,如果distinct值比較少,那執(zhí)行效率還是非常高的,甚至有可能比nl更高.

**** hint

UNNEST – 子查詢展開,不讓子查詢嵌套在里面,也就是這里說的子查詢非嵌套化.

NO_UNNEST – 子查詢嵌套化.

總結(jié):

看來CBO很多時候遇到一些寫法也做不到我們想的那樣,所以需要我們手動做子查詢擴(kuò)展;

最近發(fā)現(xiàn)好多sql的過濾條件 ( a.id=1 or exists/in …子查詢) 都選擇了filter 執(zhí)行計劃,都選擇了union all 做的解決。

?著作權(quán)歸作者所有,轉(zhuǎn)載或內(nèi)容合作請聯(lián)系作者
【社區(qū)內(nèi)容提示】社區(qū)部分內(nèi)容疑似由AI輔助生成,瀏覽時請結(jié)合常識與多方信息審慎甄別。
平臺聲明:文章內(nèi)容(如有圖片或視頻亦包括在內(nèi))由作者上傳并發(fā)布,文章內(nèi)容僅代表作者本人觀點,簡書系信息發(fā)布平臺,僅提供信息存儲服務(wù)。

相關(guān)閱讀更多精彩內(nèi)容

友情鏈接更多精彩內(nèi)容