SQL中過濾條件放在on和where中的區別

2021-07-28 11:43:26 字數 1332 閱讀 4168

今天接到螞蟻金服的電面,問了sql中過濾條件放在on和where中的區別,當時滿腦子是inner join,覺得沒區別啊。後來才想起來,連線查詢除了inner join還有right join,left join。汗吶,當時還是太緊張了。這裡做一下記錄吧。

join過程可以這樣理解:首先兩個表做乙個笛卡爾積,on後面的條件是對這個笛卡爾積做乙個過濾形成一張臨時表,如果沒有where就直接返回結果,如果有where就對上一步的臨時表再進行過濾。下面看實驗:

先準備兩張表:

先執行inner join:

結果沒有區別,前者是先求笛卡爾積然後按照on後面的條件進行過濾,後者是先用on後面的條件過濾,再用where的條件過濾。

再看看左連線left join

這下看出來不對了,id為4的記錄還在,這是由left join的特性決定的,使用left join時on後面的條件只對右表有效(可以看到右表的id=4的記錄沒了)

where的過濾作用就出來了。。。

右連線的原理是一樣的。。

到這裡就真相大白了inner join中on和where沒區別,右連線和左連線就不一樣了。

SQL中條件放在on後與where後的區別

sql中on條件與where條件的區別 資料庫在通過連線兩張或多張表來返回記錄時,都會生成一張中間的臨時表,然後再將這張臨時表返回給使用者。在使用left jion時,on和where條件的區別如下 1 on條件是在生成臨時表時使用的條件,它不管on中的條件是否為真,都會返回左邊表中的記錄。2 wh...

關於SQL語句外連線中的過濾條件

使用左外連線時,注意以下兩點 假設有以下兩張表 a表 id active11 2131 40b表 idaid active111 11210 222123 21這裡兩張表呈現為主從關係,a表為父 主 表,b表為子 副 表。兩張表的id欄位都是主鍵,b表的aid欄位為指向a表的外來鍵。兩張表中的act...

SQL中迴圈和條件語句

1 if語句使用示例 declare a int set a 12 if a 100 begin print a end else begin print no end2 while語句使用示例 declare i int set i 1 while i 30 begin insert into t...