麻豆小视频在线观看_中文黄色一级片_久久久成人精品_成片免费观看视频大全_午夜精品久久久久久久99热浪潮_成人一区二区三区四区

首頁 > 數(shù)據(jù)庫 > 文庫 > 正文

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

2020-10-29 21:46:18
字體:
供稿:網(wǎ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é)

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

發(fā)表評(píng)論 共有條評(píng)論
用戶名: 密碼:
驗(yàn)證碼: 匿名發(fā)表
主站蜘蛛池模板: 亚洲精品久久久久久 | 成人免费一区 | 吾色视频| 黄色特级片黄色特级片 | 欧美日韩国产一区二区三区在线观看 | 欧美淫视频 | 久久久久久久爱 | 天天夜碰日日摸日日澡性色av | 神马久久精品综合 | 亚洲射逼| 久久久久免费电影 | 国产精品自在线拍 | 国产一区二区视频精品 | 在线免费黄色网 | 特级黄色小说 | 久久精品国产清自在天天线 | 中文字幕视频在线播放 | 精品一区二区久久久久久久网精 | 色播视频在线播放 | 极品美女一级毛片 | 最近日本电影hd免费观看 | 久久久国产精品免费观看 | 日本成年免费网站 | 久久精品视频日本 | 国产一级毛片a | av日韩在线免费观看 | 四季久久免费一区二区三区四区 | 99视频有精品| 久久久久久久久久久亚洲 | 91久久久久久久久久久久久 | 国产福利视频在线观看 | 日韩黄色片免费看 | 国产69精品久久久久久久久久 | 伦一区二区三区中文字幕v亚洲 | 国产噜噜噜噜噜久久久久久久久 | 免看黄大片aa | 国产成人网 | 亚洲国产精品久久久久制服红楼梦 | 黄色的视频免费观看 | 国产一区不卡 | 国产精品久久久免费看 |