本文**:
select * from a
where id in(select id from b)
以上查詢使用了in語句,in()只執行一次,它查出b表中的所有id欄位並快取起來.之後,檢查a表的id是否與b表中的id相等,如果相等則將a表的記錄加入結果集中,直到遍歷完a表的所有記錄.
它的查詢過程類似於以下過程
list resultset=;
array a=(select * from a);
array b=(select id from b);
for(int i=0;i
for(int j=0;j
if(a[i].id==b[j].id) }}
return resultset;
可以看出,當b表資料較大時不適合使用in(),因為它會b表資料全部遍歷一次.
如:a表有10000條記錄,b表有1000000條記錄,那麼最多有可能遍歷10000*1000000次,效率很差.
再如:a表有10000條記錄,b表有100條記錄,那麼最多有可能遍歷10000*100次,遍歷次數大大減少,效率大大提公升.
結論:in()適合b錶比a表資料小的情況
select a.* from a a
where exists(select 1 from b b where a.id=b.id)
以上查詢使用了exists語句,exists()會執行a.length次,它並不快取exists()結果集,因為exists()結果集的內容並不重要,重要的是結果集中是否有記錄,如果有則返回true,沒有則返回false.
它的查詢過程類似於以下過程
list resultset=;
array a=(select * from a)
for(int i=0;i
if(exists(a[i].id)
}return resultset;
當b錶比a表資料大時適合使用exists(),因為它沒有那麼遍歷操作,只需要再執行一次查詢就行.
如:a表有10000條記錄,b表有1000000條記錄,那麼exists()會執行10000次去判斷a表中的id是否與b表中的id相等.
如:a表有10000條記錄,b表有100000000條記錄,那麼exists()還是執行10000次,因為它只執行a.length次,可見b表資料越多,越適合exists()發揮效果.
再如:a表有10000條記錄,b表有100條記錄,那麼exists()還是執行10000次,還不如使用in()遍歷10000*100次,因為in()是在記憶體裡遍歷比較,而exists()需要查詢資料庫,我們都知道查詢資料庫所消耗的效能更高,而記憶體比較很快.
結論:exists()適合b錶比a表資料大的情況
當a表資料與b表資料一樣大時,in與exists效率差不多,可任選乙個使用.
關於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的區別
一般來說,這兩個是用來做兩張 或更多 表聯合查詢用的,in是把外表和內錶作hash 連線,而exists 是對外表作loop 迴圈,假設有a b兩個表,使用時是這樣的 1 select from a where id in select id from b 使用in 2 select from a ...