今天接到螞蟻金服的電面吞鸭,問了sql中過濾條件放在on和where中的區(qū)別灼擂,當(dāng)時滿腦子是inner join围详,覺得沒區(qū)別啊。后來才想起來衩婚,連接查詢除了inner join還有right join窜护,left join。汗吶非春,當(dāng)時還是太緊張了柱徙。這里做一下記錄吧。
join過程可以這樣理解:首先兩個表做一個笛卡爾積奇昙,on后面的條件是對這個笛卡爾積做一個過濾形成一張臨時表坐搔,如果沒有where就直接返回結(jié)果,如果有where就對上一步的臨時表再進(jìn)行過濾敬矩。下面看實(shí)驗:
先準(zhǔn)備兩張表:
先執(zhí)行inner join:
select * from person p inner join account a on p.id=a.id and p.id!=4 and a.id!=4;
select * from person p inner join account a on p.id=a.id where p.id!=4 and a.id!=4;
結(jié)果沒有區(qū)別概行,前者是先求笛卡爾積然后按照on后面的條件進(jìn)行過濾,后者是先用on后面的條件過濾弧岳,再用where的條件過濾凳忙。
再看看左連接left join
select * from person p left join account a on p.id=a.id and p.id!=4 and a.id!=4;
這下看出來不對了业踏,id為4的記錄還在,這是由left join的特性決定的涧卵,使用left join時on后面的條件只對右表有效(可以看到右表的id=4的記錄沒了)
select * from person p left join account a on p.id=a.id where p.id!=4 and a.id!=4;
where的過濾作用就出來了勤家。。柳恐。
右連接的原理是一樣的伐脖。。
到這里就真相大白了inner join中on和where沒區(qū)別乐设,右連接和左連接就不一樣了讼庇。
---------------------
作者:古月慕南
來源:CSDN
原文:https://blog.csdn.net/u013468917/article/details/61933994
版權(quán)聲明:本文為博主原創(chuàng)文章,轉(zhuǎn)載請附上博文鏈接近尚!