當前位置:首頁 » 編程語言 » sqlexistsin

sqlexistsin

發布時間: 2025-01-26 03:43:27

『壹』 sql中in和exist語句的區別

兩者都能實現表功能查詢,主要區別如下:

1、適用表的類型不同。

in是子查詢為驅動表,外面的表為被驅動表,故適用於子查詢結果集小而外面的表結果集大的情況。

exists是外面的表位驅動表,子查詢裡面的表為被驅動表,故適用於外面的表結果集小而子查詢結果集大的情況。

2、子查詢關聯不同。

exists一般都是關聯子查詢。對於關聯子查詢,必須先執行外層查詢,接著對所有通過過濾條件的記錄,執行內層查詢。外層查詢和內層查詢相互依賴,因為外層查詢會把數據傳遞給內層查詢。

in則一般都是非關聯子查詢,非關聯子查詢則必須先完成內層查詢之後,外層查詢才能介入。

3、執行次數不同。

IN 語句:只執行一次,確定給定的值是否與子查詢或列表中的值相匹配。in在查詢的時候,首先查詢子查詢的表,然後將內表和外表做一個笛卡爾積,然後按照條件進行篩選。所以相對內表比較小的時候,in的速度較快。

EXISTS語句:執行次數根據表的長度而定。指定一個子查詢,檢測行的存在。遍歷循環外表,然後看外表中的記錄有沒有和內表的數據一樣的。匹配上就將結果放入結果集中。

『貳』 SQL中IN和EXISTS用法的區別

SQL中IN和EXISTS用法的區別
NOT IN

SELECT DISTINCT MD001 FROM BOMMD WHERE MD001 NOT IN (SELECT MC001 FROM BOMMC)
NOT EXISTS,exists的用法跟in不一樣,一般都需要和子表進行關聯,而且關聯時,需要用索引,這樣就可以加快速度
select DISTINCT MD001 from BOMMD WHERE NOT EXISTS (SELECT MC001 FROM BOMMC where BOMMC.MC001 = BOMMD.MD001)
exists是用來判斷是否存在的,當exists(查詢)中的查詢存在結果時則返回真,否則返回假。not exists則相反。
exists做為where 條件時,是先對where 前的主查詢詢進行查詢,然後用主查詢的結果一個一個的代入exists的查詢進行判斷,如果為真則輸出當前這一條主查詢的結果,否則不輸出。

in和exists

in 是把外表和內表作hash 連接,而exists是對外表作loop循環,每次loop循環再對內表進行查詢。一直以來認為exists比in效率高的說法是不準確的。
如果查詢的兩個表大小相當,那麼用in和exists差別不大。
如果兩個表中一個較小,一個是大表,則子查詢表大的用exists,子查詢表小的用in:
例如:表A(小表),表B(大表)1:select * from A where cc in (select cc from B)
效率低,用到了A表上cc列的索引;select * from A where exists(select cc from B where cc=A.cc)
效率高,用到了B表上cc列的索引。
相反的2:select * from B where cc in (select cc from A)
效率高,用到了B表上cc列的索引;select * from B where exists(select cc from A where cc=B.cc)
效率低,用到了A表上cc列的索引。
not in 和not exists如果查詢語句使用了not in 那麼內外表都進行全表掃描,沒有用到索引;而not extsts 的子查詢依然能用到表上的索引。所以無論那個表大,用not exists都比not in要快。
in 與 =的區別
select name from student where name in ('zhang','wang','li','zhao');

select name from student where name='zhang' or name='li' or name='wang' or name='zhao'
的結果是相同的。

『叄』 SqlServer中in和exists的區別效率問題

in和exists
in 是把外表和內表作hash 連接,而exists是對外表作loop循環,每次loop循環再對內表梁或進行查詢。

如果兩個表中一個較小,一個是大表悄渣神,則子查詢表大的用exists,子查啟虧詢表小的用in:
例如:表A(小表),表B(大表)1:select * from A where cc in (select cc from B)
效率低,用到了A表上cc列的索引;select * from A where exists(select cc from B where cc=A.cc)
效率高,用到了B表上cc列的索引。
相反的2:select * from B where cc in (select cc from A)
效率高,用到了B表上cc列的索引;select * from B where exists(select cc from A where cc=B.cc)
效率低,用到了A表上cc列的索引。
not in 和not exists如果查詢語句使用了not in 那麼內外表都進行全表掃描,沒有用到索引;而not extsts 的子查詢依然能用到表上的索引。所以無論那個表大,用not exists都比not in要快。

in 與 =的區別
select name from student where name in ('zhang','wang','li','zhao');與
select name from student where name='zhang' or name='li' or
name='wang' or name='zhao'
的結果是相同的。

『肆』 關於sql中in 和 exists 的效率問題,in真的效率低嗎

關於sql中in 和 exists 的效率問題,in真的效率低嗎
in和exists
in 是把外表和內表作hash 連接,而exists是對外表作loop循環,每次loop循環再對內表進行查詢。

如果兩個表中一個較小,一個是大表,則子查詢表大的用exists,子查詢表小的用in:
例如:表A(小表),表B(大表)1:select * from A where cc in (select cc from B)
效率低,用到了A表上cc列的索引;select * from A where exists(select cc from B where cc=A.cc)
效率高,用到了B表上cc列的索引。

『伍』 Oracle SQL的exists與in

兩個用法本來就有區別,IN判斷欄位的值有沒有列表中,列表中的值少的情況下直接用IN,多的情況下建議用JOIN連接;EXISTS條件是判斷子查詢存在不存在符合的記錄,並且只有有一條記錄符合條件就判定EXISTS成立。

熱點內容
我的世界粘液科技空島伺服器1122 發布:2025-01-27 06:39:59 瀏覽:111
網站搭建伺服器配置 發布:2025-01-27 06:34:48 瀏覽:174
我的世界裡寶可夢伺服器怎麼抓寵物 發布:2025-01-27 06:14:49 瀏覽:86
wikiphp 發布:2025-01-27 06:10:03 瀏覽:204
手機怎麼壓縮gif 發布:2025-01-27 06:01:42 瀏覽:90
linux怎麼返回 發布:2025-01-27 06:00:06 瀏覽:651
騰訊雲伺服器英文縮寫 發布:2025-01-27 05:38:03 瀏覽:416
在java什麼是實現 發布:2025-01-27 05:30:28 瀏覽:224
加密電腦系統 發布:2025-01-27 05:18:34 瀏覽:504
喬晶晶把密碼改成自己最好的成績是多少 發布:2025-01-27 05:15:28 瀏覽:247