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

首頁 > 數據庫 > SQL Server > 正文

INEXISTS與NOT INNOT EXISTS 的優化原則小結

2024-08-31 00:58:37
字體:
來源:轉載
供稿:網友
1. EXISTS的執行流程
select * from t1 where exists ( select null from t2 where y = x )
可以理解為:

復制代碼 代碼如下:


for x in ( select * from t1 )
loop
if ( exists ( select null from t2 where y = x.x )
then
OUTPUT THE RECORD
end if
end loop


對于in 和 exists的性能區別:
如果子查詢得出的結果集記錄較少,主查詢中的表較大且又有索引時應該用in,反之如果外層的主查詢記錄較少,子查詢中的表大,又有索引時使用exists。
其實我們區分in和exists主要是造成了驅動順序的改變(這是性能變化的關鍵),如果是exists,那么以外層表為驅動表,先被訪問,如果是IN,那么先執行子查詢,所以我們會以驅動表的快速返回為目標,那么就會考慮到索引及結果集的關系了
另外IN時不對NULL進行處理,如:
select 1 from dual where null in (0,1,2,null)
結果為空。

2. NOT IN 與NOT EXISTS:
NOT EXISTS的執行流程

復制代碼 代碼如下:


select .....
from rollup R
where not exists ( select 'Found' from title T
where R.source_id = T.Title_ID);


可以理解為:

復制代碼 代碼如下:


for x in ( select * from rollup )
loop
if ( not exists ( that query ) ) then
OUTPUT
end if;
end;


注意:NOT EXISTS 與 NOT IN 不能完全互相替換,看具體的需求。如果選擇的列可以為空,則不能被替換。
例如下面語句,看他們的區別:
select x,y from t;
x y
------ ------
1 3
3 1
1 2
1 1
3 1
5
select * from t where x not in (select y from t t2 )
no rows
select * from t where not exists (select null from t t2
where t2.y=t.x )
x y
------ ------
5 NULL
所以要具體需求來決定
對于not in 和 not exists的性能區別:
not in 只有當子查詢中,select 關鍵字后的字段有not null約束或者有這種暗示時用not in,另外如果主查詢中表大,子查詢中的表小但是記錄多,則應當使用not in,并使用anti hash join.
如果主查詢表中記錄少,子查詢表中記錄多,并有索引,可以使用not exists,另外not in最好也可以用/*+ HASH_AJ */或者外連接+is null
NOT IN 在基于成本的應用中較好
比如:

復制代碼 代碼如下:


select .....
from rollup R
where not exists ( select 'Found' from title T
where R.source_id = T.Title_ID);


改成(佳)
select ......
from title T, rollup R
where R.source_id = T.Title_id(+)
and T.Title_id is null;
或者(佳)
sql> select /*+ HASH_AJ */ ...
from rollup R
where ource_id NOT IN ( select ource_id
from title T
where ource_id IS NOT NULL )
注意:上面只是從理論上提出了一些建議,最好的原則是大家在上面的基礎上,能夠使用執行計劃來分析,得出最佳的語句的寫法。
'//=============================
exists,not exists總結

1 exists
SELECT * FROM anken_m WHERE EXISTS(
SELECT my_list_temp_m.sales_code
FROM my_list_temp_m
WHERE my_list_temp_m.sales_code=anken_m.sales_code)
說明:
1) 查詢在anken_m表和my_list_temp_m表中都存在的sales_code。
2) sales_code是anken_m的主鍵,my_list_temp_m的外鍵。
注意:
1) 外層查詢表anken_m是查詢的對象。
2) 內層查詢表my_list_temp_m是條件對象。
3) 內外層的查詢表不能相同。
4) 作為關聯條件的anken_m表不需要在內層查詢FROM后添加。
5) my_list_temp_m.sales_code=anken_m.sales_code條件的左右順序不影響查詢結果。

2 not exists
SELECT * FROM anken_m WHERE NOT EXISTS(
SELECT my_list_temp_m.sales_code
FROM my_list_temp_m
WHERE my_list_temp_m.sales_code=anken_m.sales_code)
說明:
1) 查詢在anken_m表中存在,但是在my_list_temp_m表中不存在的sales_code。
2) sales_code是anken_m的主鍵,my_list_temp_m的外鍵。
注意:
1) 外層查詢表anken_m是查詢的對象。
2) 內層查詢表my_list_temp_m是條件對象。
3) 內外層的查詢表不能相同。
4) 作為關聯條件的anken_m表不需要在內層查詢FROM后添加。
5) my_list_temp_m.sales_code=anken_m.sales_code條件的左右順序不影響查詢結果。

3 綜合運用
UPDATE anken_m
SET(plan_type_code, branch_name, business_type_code)
=(SELECT anken.plan_type_code,anken.branch_name,anken.business_type_code
FROM anken
WHERE anken.sales_code=anken_m.sales_code)
WHERE EXISTS (
SELECT anken.sales_code
FROM anken,my_list_temp_m
WHERE my_list_temp_m.sales_code=anken.sales_code
AND anken.sales_code=anken_m.sales_code
)
說明:
1) 用一個表的記錄數據更新另一個表的記錄數據。
2) 用一個SQL語句進行批量更新。
2) sales_code是anken,anken_m的主鍵,my_list_temp_m的外鍵。
注意:
1) set 語句中的要被更新字段必須跟數據源字段一一對應,另外數據源查詢中的條件必須限定一條記錄。也就是根據sales_code可以唯一確定anken的一條記錄,和anken_m的一條記錄,這樣才能保證要被更新的記錄和數據源記錄的主鍵是相同的。
2) 根據WHERE EXISTS語句可以確定數據源記錄的范圍,也就是可以用anken表中哪些記錄更新anken_m表。所以anken_m不需要在WHERE EXISTS語句中的FROM后添加。
發表評論 共有條評論
用戶名: 密碼:
驗證碼: 匿名發表
亚洲香蕉成人av网站在线观看_欧美精品成人91久久久久久久_久久久久久久久久久亚洲_热久久视久久精品18亚洲精品_国产精自产拍久久久久久_亚洲色图国产精品_91精品国产网站_中文字幕欧美日韩精品_国产精品久久久久久亚洲调教_国产精品久久一区_性夜试看影院91社区_97在线观看视频国产_68精品久久久久久欧美_欧美精品在线观看_国产精品一区二区久久精品_欧美老女人bb
国产精品福利小视频| 久久亚洲影音av资源网| 日韩资源在线观看| 国产成人精品优优av| 久久久久久久久久久免费| 色噜噜狠狠狠综合曰曰曰| 2025国产精品视频| 国产亚洲一级高清| 日本伊人精品一区二区三区介绍| 主播福利视频一区| 欧美成年人视频| 国产激情久久久久| 亚洲电影免费在线观看| 欧美成人精品不卡视频在线观看| 日韩午夜在线视频| 日韩精品免费在线视频| 欧美在线观看日本一区| 亚洲第一网站男人都懂| 国产成人精品a视频一区www| 热re99久久精品国产66热| 亚洲综合在线播放| 俺去亚洲欧洲欧美日韩| 亚洲美女av电影| 亚洲精品98久久久久久中文字幕| 亚洲第一综合天堂另类专| 97人洗澡人人免费公开视频碰碰碰| 色七七影院综合| 精品视频久久久久久| 性视频1819p久久| 久久久免费电影| 国产精品视频内| 成人激情黄色网| 中文字幕一精品亚洲无线一区| 91av在线不卡| 1769国产精品| 国产精品高潮呻吟久久av野狼| 日韩福利视频在线观看| 亚洲最大福利视频网| 欧美成人免费视频| 日韩亚洲精品视频| 成人久久久久爱| 国产精品欧美风情| 国产精品高清网站| 亚洲精品av在线| 久久亚洲精品视频| 自拍偷拍亚洲在线| 亚洲裸体xxxx| 91亚洲精品在线| 色偷偷91综合久久噜噜| 亚洲一区二区三区视频播放| 日本久久亚洲电影| 日韩亚洲欧美成人| 亚洲天堂网站在线观看视频| 国产精品都在这里| 92版电视剧仙鹤神针在线观看| 成人精品网站在线观看| 欧美日韩视频在线| 成人激情在线观看| 国产亚洲视频中文字幕视频| 中文字幕av一区中文字幕天堂| 久久久久国产视频| 日韩一区二区av| 欧美亚洲免费电影| 欧美日韩性生活视频| 欧美精品少妇videofree| 欧美日韩视频免费播放| 成人免费视频网址| 97视频在线观看免费高清完整版在线观看| 欧美富婆性猛交| 在线观看成人黄色| 国产精品xxx视频| 日韩免费在线免费观看| 91久久精品在线| 红桃视频成人在线观看| 自拍偷拍亚洲在线| 久久久久久久久久久网站| 国产美女精品视频免费观看| 欧美国产乱视频| xxxxxxxxx欧美| 欧美一区二区大胆人体摄影专业网站| 亚洲性69xxxbbb| 日韩高清中文字幕| 欧美激情精品久久久久久大尺度| 中文字幕欧美日韩| 欧美高清视频免费观看| 日韩精品免费一线在线观看| 中文字幕无线精品亚洲乱码一区| 亚洲免费伊人电影在线观看av| 国产欧美久久久久久| 久久在线免费视频| 日本韩国欧美精品大片卡二| 日日狠狠久久偷偷四色综合免费| 久久亚洲电影天堂| 国产精品久久av| 亚洲在线观看视频| 久久精品国产欧美激情| 91精品国产91久久| 久久综合伊人77777| 欧美一级高清免费播放| 欧美日韩爱爱视频| 亚洲无线码在线一区观看| 欧美视频国产精品| 国产国产精品人在线视| 国内精品视频在线| 亚洲人成网站色ww在线| 久久精品国产视频| 国产国产精品人在线视| 亚洲色图av在线| 欧美黑人极品猛少妇色xxxxx| 九九久久综合网站| 亚洲自拍偷拍色片视频| 日本免费在线精品| 精品国产91久久久久久老师| 精品视频在线播放色网色视频| 久久69精品久久久久久久电影好| 欧美xxxx做受欧美| 欧美精品日韩三级| 久久99精品久久久久久青青91| 日韩高清av一区二区三区| 午夜剧场成人观在线视频免费观看| 伊人伊人伊人久久| 久久久综合免费视频| 欧美亚洲国产精品| 4438全国亚洲精品在线观看视频| 日韩av片电影专区| 欧美在线视频播放| 精品欧美国产一区二区三区| 国产mv免费观看入口亚洲| 黑人狂躁日本妞一区二区三区| 久久综合久久88| 韩国三级日本三级少妇99| 亚洲二区在线播放视频| 91探花福利精品国产自产在线| 亚洲精美色品网站| 欧美丰满少妇xxxxx做受| 日韩精品在线播放| 国产精品视频网址| 欧美大片在线免费观看| 欧美在线视频观看| 久久精品色欧美aⅴ一区二区| 久久久免费观看| 97久久精品视频| 国产成人中文字幕| 欧美一区二区三区精品电影| 亚洲品质视频自拍网| 97视频国产在线| 岛国视频午夜一区免费在线观看| www亚洲欧美| 国内精品久久久久影院优| 国产成人精品综合久久久| 欧洲成人在线观看| 色综合91久久精品中文字幕| 欧美超级乱淫片喷水| 在线精品视频视频中文字幕| 国产精品国语对白| 国产成人亚洲综合青青| 精品久久久久久久久久久久久| 欧美大片免费观看在线观看网站推荐| 国产成人精品一区二区三区| 国产美女直播视频一区| 欧美激情一区二区久久久| 亚洲电影在线看| 精品久久久国产| 最近2019中文字幕大全第二页|