這篇文章主要介紹SQL中過濾條件放on和where中的區(qū)別有哪些,文中介紹的非常詳細(xì),具有一定的參考價值,感興趣的小伙伴們一定要看完!
成都創(chuàng)新互聯(lián)長期為上千余家客戶提供的網(wǎng)站建設(shè)服務(wù),團(tuán)隊從業(yè)經(jīng)驗10年,關(guān)注不同地域、不同群體,并針對不同對象提供差異化的產(chǎn)品和服務(wù);打造開放共贏平臺,與合作伙伴共同營造健康的互聯(lián)網(wǎng)生態(tài)環(huán)境。為扎囊企業(yè)提供專業(yè)的網(wǎng)站建設(shè)、成都網(wǎng)站設(shè)計,扎囊網(wǎng)站改版等技術(shù)服務(wù)。擁有10余年豐富建站經(jīng)驗和眾多成功案例,為您定制開發(fā)。
join過程可以這樣理解:首先兩個表做一個笛卡爾積,on后面的條件是對這個笛卡爾積做一個過濾形成一張臨時表,如果沒有where就直接返回結(jié)果,如果有where就對上一步的臨時表再進(jìn)行過濾。下面看實驗:
先準(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ū)別,右連接和左連接就不一樣了。
以上是“SQL中過濾條件放on和where中的區(qū)別有哪些”這篇文章的所有內(nèi)容,感謝各位的閱讀!希望分享的內(nèi)容對大家有幫助,更多相關(guān)知識,歡迎關(guān)注創(chuàng)新互聯(lián)行業(yè)資訊頻道!