亚洲香蕉成人av网站在线观看_欧美精品成人91久久久久久久_久久久久久久久久久亚洲_热久久视久久精品18亚洲精品_国产精自产拍久久久久久_亚洲色图国产精品_91精品国产网站_中文字幕欧美日韩精品_国产精品久久久久久亚洲调教_国产精品久久一区_性夜试看影院91社区_97在线观看视频国产_68精品久久久久久欧美_欧美精品在线观看_国产精品一区二区久久精品_欧美老女人bb

首頁(yè) > 數(shù)據(jù)庫(kù) > Oracle > 正文

oracle中not exists對(duì)外層查詢的影響詳解

2024-08-29 13:59:46
字體:
來(lái)源:轉(zhuǎn)載
供稿:網(wǎng)友

前言

最近同事發(fā)現(xiàn)了一個(gè)問(wèn)題,在12c中跑的buffer get很高,但是在10g中跑的buffer很低。懷疑是不是12c的優(yōu)化器有問(wèn)題。

這個(gè)10g的環(huán)境和12c的環(huán)境,數(shù)據(jù)量大致一樣,只是有很少部分的不同,但是就是這個(gè)很少部分不同,造成了not exists中的子查詢返回不同的值,進(jìn)而對(duì)外層查詢產(chǎn)生不同的影響。

我們來(lái)用如下的代碼模擬一下。

初始化數(shù)據(jù):

--10gdrop table t1;drop table t2; create table t1 (id number,name varchar2(20),dep_id varchar2(10));create table t2 (id number,name varchar2(20),dep_id varchar2(10)); insert into t1 select rownum,'a','kk' from dual connect by level <=3000000;insert into t2 select rownum,'a','kk' from dual connect by level <=1000000;insert into t2 select rownum,'a','mm' from dual; commit;  --12cdrop table t1;drop table t2; create table t1 (id number,name varchar2(20),dep_id varchar2(10));create table t2 (id number,name varchar2(20),dep_id varchar2(10));  insert into t1 select rownum,'a','kk' from dual connect by level <=3000000;insert into t2 select rownum,'a','kk' from dual connect by level <=1000000; commit;

我們看到,12c的數(shù)據(jù)和10g只是有很少的差別,t1表12c和10g都一樣,t2表在12c只是少了一行數(shù)據(jù)。

--10gSQL> select dep_id,count(*) from t1 group by dep_id; DEP_ID     COUNT(*)-------------------- ----------kk      3000000 SQL> select dep_id,count(*) from t2 group by dep_id; DEP_ID     COUNT(*)-------------------- ----------mm       1kk      1000000 SQL>  --12cSQL> select dep_id,count(*) from t1 group by dep_id; DEP_ID     COUNT(*)-------------------- ----------kk      3000000 SQL> select dep_id,count(*) from t2 group by dep_id; DEP_ID     COUNT(*)-------------------- ----------kk      1000000 SQL>

我們將要執(zhí)行的sql語(yǔ)句是:

select count(*) from t1, t2 where t1.id = t2.id and t1.dep_id = 'kk' and not exists (select 1   from t1, t2   where t1.id = t2.id   and t2.dep_id = 'mm');

我們先來(lái)看執(zhí)行情況的差距,10g的bufferget小,12c多:

--10gSQL> select /*+ gather_plan_statistics */ count(*) from t1,t2 where t1.id=t2.id and t1.dep_id='kk' and not exists (select 1 from t1,t2 where t1.id=t2.id and t2.dep_id='mm');  COUNT(*)----------   0 SQL> select* from table(dbms_xplan.display_cursor(null,null,'ALLSTATS LAST')); PLAN_TABLE_OUTPUT----------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------SQL_ID 22t5mb43w55pr, child number 0-------------------------------------select /*+ gather_plan_statistics */ count(*) from t1,t2 where t1.id=t2.id and t1.dep_id='kk' and notexists (select 1 from t1,t2 where t1.id=t2.id and t2.dep_id='mm') Plan hash value: 3404612428 ------------------------------------------------------------------------------------------------------------------| Id | Operation   | Name | Starts | E-Rows | A-Rows | A-Time | Buffers | OMem | 1Mem | Used-Mem |------------------------------------------------------------------------------------------------------------------| 0 | SELECT STATEMENT  |  |  1 |  |  1 |00:00:00.02 | 2086 |  |  |   || 1 | SORT AGGREGATE  |  |  1 |  1 |  1 |00:00:00.02 | 2086 |  |  |   ||* 2 | FILTER    |  |  1 |  |  0 |00:00:00.02 | 2086 |  |  |   ||* 3 | HASH JOIN   |  |  0 | 901K|  0 |00:00:00.01 |  0 | 39M| 5518K|   || 4 |  TABLE ACCESS FULL| T2 |  0 | 901K|  0 |00:00:00.01 |  0 |  |  |   ||* 5 |  TABLE ACCESS FULL| T1 |  0 | 2555K|  0 |00:00:00.01 |  0 |  |  |   ||* 6 | HASH JOIN   |  |  1 |  23 |  1 |00:00:00.02 | 2086 | 1517K| 1517K| 612K (0)||* 7 |  TABLE ACCESS FULL| T2 |  1 |  23 |  1 |00:00:00.02 | 2082 |  |  |   || 8 |  TABLE ACCESS FULL| T1 |  1 | 2555K|  1 |00:00:00.01 |  4 |  |  |   |------------------------------------------------------------------------------------------------------------------ Predicate Information (identified by operation id):---------------------------------------------------  2 - filter( IS NULL) 3 - access("T1"."ID"="T2"."ID") 5 - filter("T1"."DEP_ID"='kk') 6 - access("T1"."ID"="T2"."ID") 7 - filter("T2"."DEP_ID"='mm') Note----- - dynamic sampling used for this statement  34 rows selected. SQL>  --12cSQL> select /*+ gather_plan_statistics */ count(*) from t1,t2 where t1.id=t2.id and t1.dep_id='kk' and not exists (select 1 from t1,t2 where t1.id=t2.id and t2.dep_id='mm');  COUNT(*)---------- 1000000 SQL> select* from table(dbms_xplan.display_cursor(null,null,'ALLSTATS LAST')); PLAN_TABLE_OUTPUT------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------SQL_ID 22t5mb43w55pr, child number 0-------------------------------------select /*+ gather_plan_statistics */ count(*) from t1,t2 wheret1.id=t2.id and t1.dep_id='kk' and not exists (select 1 from t1,t2where t1.id=t2.id and t2.dep_id='mm') Plan hash value: 1692274438 --------------------------------------------------------------------------------------------------------------------| Id | Operation    | Name | Starts | E-Rows | A-Rows | A-Time | Buffers | OMem | 1Mem | Used-Mem |--------------------------------------------------------------------------------------------------------------------| 0 | SELECT STATEMENT  |  |  1 |  |  1 |00:00:00.79 | 10662 |  | |  || 1 | SORT AGGREGATE  |  |  1 |  1 |  1 |00:00:00.79 | 10662 |  | |  ||* 2 | FILTER    |  |  1 |  | 1000K|00:00:00.74 | 10662 |  | |  ||* 3 | HASH JOIN   |  |  1 | 1215K| 1000K|00:00:00.52 | 8579 | 43M| 6111K| 42M (0)|| 4 |  TABLE ACCESS FULL | T2 |  1 | 1215K| 1000K|00:00:00.01 | 2083 |  | |  ||* 5 |  TABLE ACCESS FULL | T1 |  1 | 2738K| 3000K|00:00:00.07 | 6496 |  | |  ||* 6 | HASH JOIN RIGHT SEMI|  |  1 |  35 |  0 |00:00:00.02 | 2083 | 1245K| 1245K| 461K (0)||* 7 |  TABLE ACCESS FULL | T2 |  1 |  23 |  0 |00:00:00.02 | 2083 |  | |  || 8 |  TABLE ACCESS FULL | T1 |  0 | 2738K|  0 |00:00:00.01 |  0 |  | |  |-------------------------------------------------------------------------------------------------------------------- Predicate Information (identified by operation id):---------------------------------------------------  2 - filter( IS NULL) 3 - access("T1"."ID"="T2"."ID") 5 - filter("T1"."DEP_ID"='kk') 6 - access("T1"."ID"="T2"."ID") 7 - filter("T2"."DEP_ID"='mm') Note----- - dynamic statistics used: dynamic sampling (level=2)  35 rows selected. SQL>SQL>

可以看到第23,24行,在10g中運(yùn)行時(shí),buffers是0,而在12c中,即78,79行,buffer是2083+6496。

也就是說(shuō)在10g中,外層查詢不進(jìn)行t1和t2的掃描,直接返回結(jié)果了,而在12c中,外層查詢還要進(jìn)行t1表和t2表層掃描才返回結(jié)果。

這其實(shí)不是10g和12c的差別,而是not exists的返回?cái)?shù)據(jù)對(duì)外層的影響。子查詢要返回0行記錄,才滿足not exist的條件,從而返回外層查詢結(jié)果。

在10g中,子查詢返回了一行記錄

--10gSQL> select 1 from t1,t2 where t1.id=t2.id and t2.dep_id='mm';    1----------   1 SQL>

不滿足not exists(即0行才滿足),所以,也就不用在外層繼續(xù)查詢了。直接返回記錄0行。

在12c中,子查詢返回0行記錄,滿足not exist的條件,所以還需要在外層查詢中繼續(xù)查詢。

--12cSQL> select count(*) from t1,t2 where t1.id=t2.id and t2.dep_id='kk';  COUNT(*)---------- 1000000 SQL> set line 1000SQL> set pages 1000SQL> col PLAN_TABLE_OUTPUT for a250SQL>SQL>SQL> select /*+ gather_plan_statistics */ count(*) from t1,t2 where t1.id=t2.id and t1.dep_id='kk' and not exists (select 1 from t1,t2 where t1.id=t2.id and t2.dep_id='kk');  COUNT(*)----------   0 SQL> select* from table(dbms_xplan.display_cursor(null,null,'ALLSTATS LAST')); PLAN_TABLE_OUTPUT---------------------------------------------------------------------------------------------------------------------------------------------------------------------------------SQL_ID c5hj2p2jt1fxf, child number 0-------------------------------------select /*+ gather_plan_statistics */ count(*) from t1,t2 wheret1.id=t2.id and t1.dep_id='kk' and not exists (select 1 from t1,t2where t1.id=t2.id and t2.dep_id='kk') Plan hash value: 1692274438 --------------------------------------------------------------------------------------------------------------------| Id | Operation    | Name | Starts | E-Rows | A-Rows | A-Time | Buffers | OMem | 1Mem | Used-Mem |--------------------------------------------------------------------------------------------------------------------| 0 | SELECT STATEMENT  |  |  1 |  |  1 |00:00:00.28 | 2087 |  | |  || 1 | SORT AGGREGATE  |  |  1 |  1 |  1 |00:00:00.28 | 2087 |  | |  ||* 2 | FILTER    |  |  1 |  |  0 |00:00:00.28 | 2087 |  | |  ||* 3 | HASH JOIN   |  |  0 | 1215K|  0 |00:00:00.01 |  0 | 69M| 7428K|   || 4 |  TABLE ACCESS FULL | T2 |  0 | 1215K|  0 |00:00:00.01 |  0 |  | |  ||* 5 |  TABLE ACCESS FULL | T1 |  0 | 2738K|  0 |00:00:00.01 |  0 |  | |  ||* 6 | HASH JOIN RIGHT SEMI|  |  1 | 2738K|  1 |00:00:00.28 | 2087 | 43M| 6111K| 42M (0)||* 7 |  TABLE ACCESS FULL | T2 |  1 | 1215K| 1000K|00:00:00.12 | 2083 |  | |  || 8 |  TABLE ACCESS FULL | T1 |  1 | 2738K|  1 |00:00:00.01 |  4 |  | |  |-------------------------------------------------------------------------------------------------------------------- Predicate Information (identified by operation id):---------------------------------------------------  2 - filter( IS NULL) 3 - access("T1"."ID"="T2"."ID") 5 - filter("T1"."DEP_ID"='kk') 6 - access("T1"."ID"="T2"."ID") 7 - filter("T2"."DEP_ID"='kk') Note----- - dynamic statistics used: dynamic sampling (level=2)  35 rows selected. SQL>

可以看到第38,39行的buffer為0.

總結(jié)

以上就是這篇文章的全部?jī)?nèi)容了,希望本文的內(nèi)容對(duì)大家的學(xué)習(xí)或者工作能帶來(lái)一定的幫助,如果有疑問(wèn)大家可以留言交流。


注:相關(guān)教程知識(shí)閱讀請(qǐng)移步到oracle教程頻道。
發(fā)表評(píng)論 共有條評(píng)論
用戶名: 密碼:
驗(yàn)證碼: 匿名發(fā)表
操人视频91| 国产探花视频在线播放| 国产精品一区二区三区在线免费观看| 亚洲你懂的在线视频| 亚洲xxxx2d动漫1| 午夜网站在线观看| 亚洲黄色在线观看视频| 五月综合激情日本mⅴ| 亚洲一区二区三区午夜| 国产福利小视频| 超碰免费在线公开| 精品三级av在线导航| 精品亚洲欧美一区| 国产精品久久久爽爽爽麻豆色哟哟| 91在线小视频| 无码日韩精品一区二区| 亚洲日产国产精品| 欧美日韩成人综合天天影院| 黄色网页在线免费观看| 国产传媒免费在线观看| 91豆麻精品91久久久久久| 欧美高清视频www夜色资源网| 手机在线看片日韩| 精品乱码一区二区三区四区| 性欧美18一19sex性欧美| 俄罗斯一级**毛片在线播放| 亚洲GV成人无码久久精品| 国产一区第一页| 国产精品成人无码| 一级一级黄色片| 亚洲卡通欧美制服中文| 亚洲资源在线播放| 亚洲午夜激情视频| 北条麻妃一区二区三区在线观看| 韩国一区二区三区在线观看| 日本不卡一区二区三区高清视频| 亚洲天堂一区| 日韩黄色免费网站| 桃乃木香奈和黑人aⅴ在线播放| 日本系列第一页| 亚洲欧美日韩在线不卡| 亚洲精品成人久久电影| 孩xxxx性bbbb欧美| 黄色在线免费观看大全| 超碰av在线免费观看| 污视频网站在线看| 国产欧美久久久精品影院| 粉嫩13p一区二区三区| 欧美h视频在线观看| 亚洲欧美一区二区精品久久久| 好吊日精品视频| 欧美成人禁片在线观看网址| 99久久婷婷国产综合| 亚洲午夜精品一区| 网站永久看片免费| 亚洲乱亚洲乱妇无码| 91精品啪在线观看国产18| 国产高清精品一区| 91夜夜蜜桃臀一区二区三区| 精品亚洲成a人在线观看| av电影在线播放高清免费观看| 成人精品久久av网站| 韩国久久久久久| 夜夜躁日日躁狠狠久久88av| 亚洲欧洲综合另类| 中国色在线观看另类| 成人高清电影网站| 日韩av一区二区在线| 亚洲欧美日韩一区成人| 亚洲视频一区二区在线观看| 亚洲欧美日韩国产成人综合一二三区| 噜噜噜在线视频| 亚洲日本久久久午夜精品| 午夜av电影一区| www视频在线观看免费| 国产传媒免费观看| 亚洲女人av| 亚洲尤物在线视频观看| 国产亚洲精品一区二555| 成人午夜av影视| 久久国产亚洲| 久久99在线观看| 国产一区二区三区免费观看在线| 精品国产区一区| 国产一区二区三区四区福利| 精品露脸国产偷人在视频| 日本黄色动态图| 亚洲国产精品久久久久婷蜜芽| 蜜桃一级网站.| 91精品福利在线| 性欧美videossex精品| 国产噜噜噜噜噜久久久久久久久| 国产偷拍一区二区| 亚洲少妇中文在线| 亚洲国产综合色| 亚洲三区在线观看无套内射| 亚洲综合伊人久久大杳蕉| 在线播放中文字幕| 欧美一级特黄视频| 国产精品毛片久久| 老师我好爽再深一点的视频| 激情小说亚洲一区| 久久视频在线看| 国产中文字字幕乱码无限| 三级成人黄色影院| 亚洲精品一区三区三区在线观看| 日韩在线精品视频| 午夜成人免费影院| 亚洲永久精品免费| 欧美精品 国产精品| 亚洲欧美日韩精品久久奇米色影视| 国产精品爱啪在线线免费观看| 高清免费日韩| 欧美精品尤物在线| 自拍偷拍校园春色| 女明星视频黄又免费| 久草视频免费在线观看| 日韩精品123| caoporn国产精品免费公开| 伊人中文字幕在线| 欧美一二三四在线| 亚洲成人中文| 午夜小视频免费| 中文字幕一区二区三中文字幕| 免费无遮挡无码永久在线观看视频| 国产美女被下药99| 欧美三级日本三级| 日韩中文av| 国产在线日韩在线| 久久久久久久久艹| 伊人久久久大香线蕉综合直播| 伊人成色综合网| 亚洲人性生活视频| 在线免费av电影| 亚洲精品日产精品乱码不卡| 精品国产一区二区三区久久久蜜臀| 国产在线激情视频| 欧美ab在线视频| 男人天堂手机在线视频| 精品国精品自拍自在线| 99国产在线| 成人性教育视频在线观看| 日韩在线中文字| 日本xxxx人| 被黑人猛躁10次高潮视频| 久久夜色精品国产欧美乱极品| 黄色一级视频免费看| 黄色美女一级片| 无遮挡又色又刺激的女人视频| 人妻 日韩 欧美 综合 制服| 夜色激情一区二区| 99re久久最新地址获取| 国产高清精品一区二区| 日韩精品无码一区二区三区| 成人av午夜影院| 日本黄色免费在线观看| 欧美激情a在线| 日韩美一区二区| 在线观看中文字幕亚洲| 在线综合亚洲欧美在线视频| 欧美午夜激情视频| 免费观看在线综合| 国产欧美日韩中文| 久久综合伊人77777麻豆最新章节| 正在播放欧美视频| 91搞黄在线观看| 欧美成人综合色| 欧美亚洲另类在线| 免费视频91蜜桃| 免费在线黄色av| 日本一级黄色大片| 成人一区二区三区在线观看| 国产欧美日本一区视频| 久久这里只有精品23| 亚洲东热激情| 日本不卡一区二区三区高清视频| 欧美第一页在线观看| 欧美jizz18性欧美| 色网综合在线观看| 欧美激情一区二区视频| 欧美日韩mv| 欧美日韩国产一中文字不卡| 欧美激情视频在线观看| 欧美日韩中文字幕一区二区| 色吧影院999| 日韩视频精品在线观看| 玖玖在线免费视频| 高清不卡一区二区在线| ass白嫩白嫩的小美女| 欧美日韩一区二区三区免费| а√最新版天堂中文在线| 四虎在线免费观看| 欧亚乱熟女一区二区在线| 成人在线国产精品| 美女一区二区在线观看| 精品人伦一区二区三区| 国内伊人久久久久久网站视频| 日本不卡的三区四区五区| 国产成人精品视频免费看| 91麻豆成人精品国产| 久久精视频免费在线久久完整在线看| 成人h视频在线观看播放| 精品无码久久久久久久| 国产高清久久| 久久女同性恋中文字幕| 在线不卡中文字幕播放| 精品日韩一区二区三区| 国产校园另类小说区| 激情欧美日韩| 影音先锋中文字幕在线观看| 国产精品一区久久久| 在线观看欧美黄色| 免费全黄无遮挡裸体毛片| 91综合久久| 亚洲 国产 图片| 亚洲第一影院| 成人午夜电影小说| 日韩一区在线看| 亚洲资源av| 成年人免费视频观看| 亚洲成人精品电影在线观看| 毛片毛片毛片毛片| 欧美日韩精品一区二区天天拍小说| 日韩美女视频一区二区在线观看| 激情偷拍久久| 成人短视频在线看| 69亚洲精品久久久蜜桃小说| 好吊日视频在线观看| 色婷婷狠狠五月综合天色拍| 精品无人乱码| 97伦理在线四区| 国产激情视频网站| av国产精品| 成人福利网站在线观看11| а√在线天堂官网| 亚洲影视在线播放| 天天摸天天舔天天操| 成年人黄视频网站| 欧美成人精品二区三区99精品| 色综合一区二区日本韩国亚洲| 99re在线观看| 欧美日韩和欧美的一区二区| 国产精品综合av一区二区国产馆| 亚洲高清视频网站| 51社区在线成人免费视频| av超碰在线观看| 亚洲在线精品视频| 天天操人人爽| 草草影院第一页| 日韩国产一二三区| 亚洲国产成人在线播放| 97在线免费公开视频| 亚洲精品美女免费| 日韩欧美国产成人精品免费| 欧美日韩生活片| 久久国产精品一区二区| 老司机精品免费视频| 免费黄色一级网站| av片在线观看网站| 欧美一区二区久久久| 自拍偷拍福利视频| 成年人av电影| 日本国产在线播放| 精品久久久久成人码免费动漫| 高跟丝袜欧美一区| 9.1麻豆精品| 国产91精品一区二区麻豆亚洲| 亚洲国产精品区| 玩弄中年熟妇正在播放| 国产精品污污网站在线观看| 国产欧美日韩综合精品二区| 精品国产91久久久久久老师| 成人国产精品一区二区免费麻豆| 精品一区电影| 久久99国产精品自在自在app| 日韩成人在线电影| 一区二区三区在线视频观看58| 国产成人免费在线观看不卡| 欧美在线观看视频一区| 欧美日韩黄色一区二区| 欧美成人手机视频| 亚洲欧洲在线观看av| 国产性猛交普通话对白| 亚洲高潮女人毛茸茸| 欧洲av一区| 91麻豆免费在线观看| 男女毛片免费视频看| 日韩最新中文字幕电影免费看| 欧美一区久久久| 国产伦精品一区二区三区视频网站| 欧美日韩亚洲一区二区三区在线观看| 国产福利电影网| 亚洲一区电影| 久久精品女人天堂| 精品人妻少妇嫩草av无码| 亚洲人成网站在线观看播放| 国内av一区二区| 一出一进一爽一粗一大视频| 精品国产一区二区三区久久狼黑人| 精品亚洲视频在线| 欧美在线激情网| 免费性色视频| 免费观看v片在线观看| 亚洲视频一区在线播放| 亚洲嫩草精品久久| 国产九九视频一区二区三区| 国产美女诱惑一区二区| 日本中文在线| 警花av一区二区三区| 色综合久久综合中文综合网| 国产免费一级视频| 日本黄色网网页| 欧美放荡的少妇| av网站免费线看精品| 国产精品成人av在线| 久草视频免费看| 青青青爽久久午夜综合久久午夜| 欧美专区一二三| 欧美精品一区二区三区四区| 欧美猛男超大videosgay| 亚洲成a人在线观看| 日本在线视频www| 国产精品伊人| 亚洲综合色成人| 四虎影院在线免费播放| 黄色免费av网站| 日韩欧美一区免费| 国产精品国产三级国产有无不卡|