主頁 > 知識(shí)庫 > SQL中過濾條件放on和where中的區(qū)別詳解

SQL中過濾條件放on和where中的區(qū)別詳解

熱門標(biāo)簽:小程序智能電話機(jī)器人 怎么申請(qǐng)400熱線電話 河北便宜電銷機(jī)器人軟件 簡單的智能語音電銷機(jī)器人 泗洪正規(guī)電話機(jī)器人找哪家 ai電話電話機(jī)器人 湖南保險(xiǎn)智能外呼系統(tǒng)產(chǎn)品介紹 怎么去開發(fā)一個(gè)電銷機(jī)器人 南昌呼叫中心外呼系統(tǒng)哪家好

前言

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

join過程可以這樣理解:首先兩個(gè)表做一個(gè)笛卡爾積,on后面的條件是對(duì)這個(gè)笛卡爾積做一個(gè)過濾形成一張臨時(shí)表,如果沒有where就直接返回結(jié)果,如果有where就對(duì)上一步的臨時(shí)表再進(jìn)行過濾。下面看實(shí)驗(yà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;

這下看出來不對(duì)了,id為4的記錄還在,這是由left join的特性決定的,使用left join時(shí)on后面的條件只對(duì)右表有效(可以看到右表的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ū)別,右連接和左連接就不一樣了。

總結(jié)

以上就是這篇文章的全部內(nèi)容了,希望本文的內(nèi)容對(duì)大家的學(xué)習(xí)或者工作具有一定的參考學(xué)習(xí)價(jià)值,如果有疑問大家可以留言交流,謝謝大家對(duì)腳本之家的支持。

您可能感興趣的文章:
  • MySQL查詢條件中放置on和where的區(qū)別分析

標(biāo)簽:瀘州 淮安 江蘇 荊門 威海 柳州 景德鎮(zhèn) 那曲

巨人網(wǎng)絡(luò)通訊聲明:本文標(biāo)題《SQL中過濾條件放on和where中的區(qū)別詳解》,本文關(guān)鍵詞  SQL,中,過濾,條件,放,和,;如發(fā)現(xiàn)本文內(nèi)容存在版權(quán)問題,煩請(qǐng)?zhí)峁┫嚓P(guān)信息告之我們,我們將及時(shí)溝通與處理。本站內(nèi)容系統(tǒng)采集于網(wǎng)絡(luò),涉及言論、版權(quán)與本站無關(guān)。
  • 相關(guān)文章
  • 下面列出與本文章《SQL中過濾條件放on和where中的區(qū)別詳解》相關(guān)的同類信息!
  • 本頁收集關(guān)于SQL中過濾條件放on和where中的區(qū)別詳解的相關(guān)信息資訊供網(wǎng)民參考!
  • 推薦文章