有兩個簡單例子,以說明 「exists」和「in」的效率問題
1) select * from t1 where exists(select 1 from t2 where t1.a=t2.a) ;
t1資料量小而t2資料量非常大時,t1<2) select * from t1 where t1.a in (select t2.a from t2) ;
t1資料量非常大而t2資料量小時,t1>>t2 時,2) 的查詢效率高。
exists 用法:
請注意 1)句中的有顏色字型的部分 ,理解其含義;
其中 「select 1 from t2 where t1.a=t2.a」 相當於乙個關聯表查詢,相當於
「select 1 from t1,t2
where t1.a=t2.a」
但是,如果你噹噹執行 1) 句括號裡的語句,是會報語法錯誤的,這也是使用exists需要注意的地方。
「exists(***)」就表示括號裡的語句能不能查出記錄,它要查的記錄是否存在。
因此「select 1」這裡的 「1」其實是無關緊要的,換成「*」也沒問題,它只在乎括號裡的資料能不能查詢出來,是否存在這樣的記錄,如果存在,這 1) 句的where 條件成立。
in 的用法:
繼續引用上面的例子
「2) select * from t1 where t1.a in (select t2.a from t2) 」
這裡的「in」後面括號裡的語句搜尋出來的字段的內容一定要相對應,一般來說,t1和t2這兩個表的a欄位表達的意義應該是一樣的,否則這樣查沒什麼意義。
打個比方:t1,t2表都有乙個字段,表示工單號,但是t1表示工單
mysql的 和 的區別 和 的區別
他們之間的區別用最直接的話來說就是 相當於對資料 加上 雙引號,相當於直接顯示資料。1 對傳入的引數視為字串,也就是它會預編譯select from user where name 比如我傳乙個csdn,那麼傳過來就是select from user where name csdn 2 將不會將傳入...
和 及 和 的區別
和 都為與,進行與運算時只有當兩個條件都為真時結果才為真,否則為假 和 都為或,進行或運算時只要兩個條件有乙個為真結果就為真,否則為假 序號邏輯運算子描述1 與2 短路與3 或 4 短路或 與 和短路與 的區別是因為進行與運算時只要第乙個條件為假時無論第二個條件的真值為什麼計算結果都為假,所以如果是...
和 以及 和 的區別
和 都可以用作邏輯與的運算子,表示邏輯與 and 當運算子兩邊的表示式的結果都為true時,整個運算結果才為true,否則,只要有一方為false,則結果為false。還具有短路的功能,即如果第乙個表示式為false,則不再計算第二個表示式,例如,對於if str null str.equals 表...