校园春色亚洲色图_亚洲视频分类_中文字幕精品一区二区精品_麻豆一区区三区四区产品精品蜜桃

主頁 > 知識庫 > SQL中過濾條件放on和where中的區別詳解

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

熱門標簽:小程序智能電話機器人 怎么申請400熱線電話 河北便宜電銷機器人軟件 簡單的智能語音電銷機器人 泗洪正規電話機器人找哪家 ai電話電話機器人 湖南保險智能外呼系統產品介紹 怎么去開發一個電銷機器人 南昌呼叫中心外呼系統哪家好

前言

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

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

先準備兩張表:

先執行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;

結果沒有區別,前者是先求笛卡爾積然后按照on后面的條件進行過濾,后者是先用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沒區別,右連接和左連接就不一樣了。

總結

以上就是這篇文章的全部內容了,希望本文的內容對大家的學習或者工作具有一定的參考學習價值,如果有疑問大家可以留言交流,謝謝大家對腳本之家的支持。

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

標簽:瀘州 淮安 江蘇 荊門 威海 柳州 景德鎮 那曲

巨人網絡通訊聲明:本文標題《SQL中過濾條件放on和where中的區別詳解》,本文關鍵詞  SQL,中,過濾,條件,放,和,;如發現本文內容存在版權問題,煩請提供相關信息告之我們,我們將及時溝通與處理。本站內容系統采集于網絡,涉及言論、版權與本站無關。
  • 相關文章
  • 下面列出與本文章《SQL中過濾條件放on和where中的區別詳解》相關的同類信息!
  • 本頁收集關于SQL中過濾條件放on和where中的區別詳解的相關信息資訊供網民參考!
  • 推薦文章
    主站蜘蛛池模板: 竹北市| 精河县| 佛冈县| 玛曲县| 古浪县| 利津县| 汾阳市| 策勒县| 武宁县| 汉阴县| 福贡县| 当雄县| 徐汇区| 密云县| 金沙县| 阳山县| 朔州市| 南宁市| 龙泉市| 江安县| 清苑县| 华容县| 石渠县| 仙居县| 安西县| 莎车县| 壶关县| 油尖旺区| 高碑店市| 红桥区| 柯坪县| 汶上县| 福清市| 道真| 广水市| 西藏| 于都县| 岚皋县| 丰顺县| 汕尾市| 若羌县|