一般來說,這兩個是用來做兩張(或更多)表聯合查詢用的,in是把外表和內錶作hash 連線,而exists 是對外表作loop 迴圈,假設有a、b兩個表,使用時是這樣的:
1、select * from a where id in (select id from b)–使用in
2、select * from a where exists(select b.id from b where b.id=a.id)–使用exists
也可以完全不使用in和exists:
3、select a.* from a,b where a.id=b.id–不使用in和exists
具體使用時到底選擇哪乙個,主要考慮查詢效率問題:
第一條語句使用了a表的索引;
第二條語句使用了b表的索引;
第三條語句同時使用了a表、b表的索引;
如果a、b表的資料量不大,那麼這三個語句執行效率幾乎無差別;
如果a表大,b錶小,顯然第一條語句效率更高,反之,則第二條語句效率更高;
第三條語句儘管同時使用了a表、b表的索引,單掃瞄次數是笛卡爾乘積,效率最差。
關於oracle中in和exists
今天看sql語句的時候發現了exists這個關鍵字,記得剛用這個關鍵字的時候只知道它和關鍵字in的作用是一樣的,當時覺得無非就是我的條件匹配到子結果集裡面的資料。今天打算把這兩個關鍵字具體怎麼回事區分一下,上網上看了一下,懂了一些兩者的區別,其中還涉及到了效能問題,很吃驚!2018 11 8再次更新...
oracle中關於生成累計和
首先建立oracle基礎表如下 現在要求分別累計各部門的工資之和 select empno,deptno,ename,sal,hiredate,sum sal over order by hiredate as totalsal from emp order by hiredate 效果如圖 當分析...
關於oracle中in和exists的區別
本文 select from a where id in select id from b 以上查詢使用了in語句,in 只執行一次,它查出b表中的所有id欄位並快取起來.之後,檢查a表的id是否與b表中的id相等,如果相等則將a表的記錄加入結果集中,直到遍歷完a表的所有記錄.它的查詢過程類似於以下...