關於oracle中in和exists

2021-08-22 13:20:55 字數 1877 閱讀 9830

今天看sql語句的時候發現了exists這個關鍵字,記得剛用這個關鍵字的時候只知道它和關鍵字in的作用是一樣的,當時覺得無非就是我的條件匹配到子結果集裡面的資料。今天打算把這兩個關鍵字具體怎麼回事區分一下,上網上看了一下,懂了一些兩者的區別,其中還涉及到了效能問題,很吃驚!

2018-11-8再次更新:

問題說明:在略懂了in 和 exists的區別之後,自認為子查詢結果集的資料少的情況下可以用 not in,但是忽略了乙個至關重要的問題,我要進行的子查詢的結果集很多,

特別說明:oracle中not in的資料引數,不可以超過1000個,否則會報sql執行出錯。所以說,同志們,還是用exists吧,血和淚的教訓啊。

同時也知道了一些關於null在子查詢in和not in的區別。

開發時候謹記:

所以當我們要去進行某乙個欄位的不等於過濾查詢時,我們要搞清楚,我們的查詢是否要包含null值。

這裡先說下exists這個關鍵字,exists返回的是乙個布林值,oracle根據true或者false進行判斷,如果為true,將結果保留進行,如果為false,則不保留。

exists會先去進行主查詢,也就是exists之前的部分,如:

select t.name,t.*** from a t where t.dr = 0 and exists (select b.id from b where b.pk = b.pk);

ps:exists中的查詢語句一定要和前面的表進行關聯,達到過濾的目的

進行完主查詢之後得到乙個結果集,再對結果集的每一行去對exits後面的語句進行匹配,為真則保留,為false則不保留,最後返回查詢的結果集。

注意:exists前面是不能加類似於欄位名的,否則會報無效關係運算的錯誤,如圖:

2018-10-19 再次強調乙個東西,就是exists 中sql語句的書寫

像上面這種寫法,達不到進行過濾的條件,exists中必須加上和外表進行的關聯的條件,否則無法達到過濾,正確寫法應該是下面這樣的寫法

可能是對於exits的用法還不夠透徹!

in關鍵字則是先去進行子查詢,也就是in之後的部分,如:

select t.name,t.*** from a t where t.dr = 0 and m.id in (select * from b m where m.pk = t.pk);

進行完子查詢之後會得到乙個結果集,和主表做笛卡爾積,然根據過濾條件得到最後的結果集。

到這裡,可以知道,如果主查詢要查的東西多,用exists,如果子表要查的東西多,用in。

特別說明:

in關鍵字在進行排序的時候使用的是hash join演算法 連線表與表,

exists關鍵字在進行排序的時候使用的是loop演算法連線表與表。

這兩種演算法具體怎麼回事還不清楚.............

這裡介紹幾個資料庫裡的名詞:

在plsql中按f5會進行sql語句的執行計畫。以下幾個名詞可能會看到,截圖如下:

oracle中關於生成累計和

首先建立oracle基礎表如下 現在要求分別累計各部門的工資之和 select empno,deptno,ename,sal,hiredate,sum sal over order by hiredate as totalsal from emp order by hiredate 效果如圖 當分析...

關於oracle中in和exists的區別

一般來說,這兩個是用來做兩張 或更多 表聯合查詢用的,in是把外表和內錶作hash 連線,而exists 是對外表作loop 迴圈,假設有a b兩個表,使用時是這樣的 1 select from a where id in select id from b 使用in 2 select from a ...

關於oracle中in和exists的區別

本文 select from a where id in select id from b 以上查詢使用了in語句,in 只執行一次,它查出b表中的所有id欄位並快取起來.之後,檢查a表的id是否與b表中的id相等,如果相等則將a表的記錄加入結果集中,直到遍歷完a表的所有記錄.它的查詢過程類似於以下...