今天看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表的所有記錄.它的查詢過程類似於以下...