1. 程式人生 > 其它 >【mySQL】left join、right join和join的區別

【mySQL】left join、right join和join的區別

哈,好久沒更新文章了,今天來說說關於mySQL那些年的小事。說到mySQL啊,用了挺久的了,但是有個問題一直在困擾著我,就是left join、join、right join和inner join等等各種join的區別。網上搜,最常見的就是一張圖解圖,如下:

真的是一張圖道清所有join的區別啊,可惜我還是看不懂,可能人比較懶,然後基本一個left join給我就是夠用的了,所以就沒怎麼去仔細研究了,但是現實還是逼我去搞清楚,索性自己動手,總算理解圖中的含義了,下面就聽我一一道來。

首先,我們先來建兩張表,第一張表命名為kemu,第二張表命名為score:

一、left join
顧名思義,就是“左連線”,表1左連線表2,以左為主,表示以表1為主,關聯上表2的資料,查出來的結果顯示左邊的所有資料,然後右邊顯示的是和左邊有交集部分的資料。如下:

select
   *
from
   kemu
left join score on kemu.id = score.id

結果集:

二、right join

“右連線”,表1右連線表2,以右為主,表示以表2為主,關聯查詢表1的資料,查出表2所有資料以及表1和表2有交集的資料,如下:

select
   *
from
   kemu
right join score on kemu.id = score.id

結果集:

三、join
join,其實就是“inner join”,為了簡寫才寫成join,兩個是表示一個的,內連線,表示以兩個表的交集為主,查出來是兩個表有交集的部分,其餘沒有關聯就不額外顯示出來,這個用的情況也是挺多的,如下

select
   *
from
   kemu
join score on kemu.id = score.id

結果集:

以上就是三種連線的區別!

https://segmentfault.com/a/1190000017369618

歡迎關注微信公眾號:大資料從業者