国产探花免费观看_亚洲丰满少妇自慰呻吟_97日韩有码在线_资源在线日韩欧美_一区二区精品毛片,辰东完美世界有声小说,欢乐颂第一季,yy玄幻小说排行榜完本

首頁 > 數據庫 > 文庫 > 正文

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

2020-10-29 21:46:18
字體:
來源:轉載
供稿:網友

前言

今天接到螞蟻金服的電面,問了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沒區別,右連接和左連接就不一樣了。

總結

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

發表評論 共有條評論
用戶名: 密碼:
驗證碼: 匿名發表
主站蜘蛛池模板: 丽水市| 庆城县| 凤城市| 四子王旗| 仪陇县| 开化县| 环江| 江陵县| 手机| 上饶市| 陇川县| 泽普县| 阿克苏市| 交口县| 望都县| 吉木萨尔县| 左权县| 达日县| 云南省| 仁寿县| 闸北区| 彰武县| 城口县| 苍南县| 香格里拉县| 乌鲁木齐市| 太白县| 锡林浩特市| 赤峰市| 鄂温| 亳州市| 体育| 东兴市| 荔浦县| 潮州市| 辽宁省| 富民县| 通化县| 吉安市| 雅江县| 仪征市|