內連線與外連線的區別

2021-10-08 06:22:30 字數 3786 閱讀 9571

在之前,我對mssql中的內連線和外連線所得出的資料集不是很清楚。這幾天重新溫習了一下sql的書本,現在的思路應該是很清楚了,現在把自己的理解發出來給大家溫習下。希望和我一樣對sql的連線語句不太理解的朋友能夠有所幫助。(發這麼菜的教程,各位大大們別笑話偶了,呵:d )

有兩個表a和表b。

表a結構如下:

aid:int;標識種子,主鍵,自增id

aname:varchar

資料情況,即用select * from a出來的記錄情況如下圖1所示:

圖1:a表資料

表b結構如下:

bid:int;標識種子,主鍵,自增id

bnameid:int

資料情況,即用select * from b出來的記錄情況如下圖2所示:

圖2:b表資料

為了把bid和aid加以區分,不讓大家有誤解,所以把bid的起始種子設定為100。

有sql基本知識的人都知道,兩個表要做連線,就必須有個連線字段,從上表中的資料可以看出,在a表中的aid和b表中的bnameid就是兩個連線字段。

下圖3說明了連線的所有記錄集之間的關係:

圖3:連線關係圖

現在我們對內連線和外連線一一講解。

1.內連線:利用內連線可獲取兩表的公共部分的記錄,即圖3的記錄集c

語句如下:select * from a join b on a.aid=b.bnameid

執行結果如下圖4所示:

圖4:內連線資料

其實select * from a,b where a.aid=b.bnameid與select * from a join b on a.aid=b.bnameid的執行結果是一樣的。

2.外連線:外連線分為兩種,一種是左連線(left join)和右連線(right join)

(1)左連線(left join):即圖3公共部分記錄集c+表a記錄集a1。

語句如下:select * from a left join b on a.aid=b.bnameid

執行結果如下圖5所示:

圖5:左連線資料

說明:在語句中,a在b的左邊,並且是left join,所以其運算方式為:a左連線b的記錄=圖3公共部分記錄集c+表a記錄集a1

在圖3中即記錄集c中的存在的aid為:2 3 6 7 8

圖1中即表a所有記錄集a中存在的aid為:1 2 3 4 5 6 7 8 9

表a記錄集a1中存在的aid=(圖1中即a表中所有aid)-(圖3中即記錄集c中存在的aid),最終得出為:1 4 5 9

由此得出圖5中a左連線b的記錄=圖3公共部分記錄集c+表a記錄集a1,

最終得出的結果圖5中可以看出bnameid及bid非null的記錄都為圖3公共部分記錄集c中的記錄;bnameid及bid為null的aid為1 4 5 9的四筆記錄就是表a記錄集a1中存在的aid。

(2)右連線(right join):即圖3公共部分記錄集c+表b記錄集b1。

語句如下:select * from a right join b on a.aid=b.bnameid

執行結果如下圖6所示:

圖6:右連線資料

說明:在語句中,a在b的左邊,並且是right join,所以其運算方式為:a右連線b的記錄=圖3公共部分記錄集c+表b記錄集b1

在圖3中即記錄集c中的存在的aid為:2 3 6 7 8

圖2中即表b所有記錄集b中存在的bnameid為:2 3 6 7 8 11

表b記錄集b1中存在的bnameid=(圖2中即b表中所有bnameid)-(圖3中即記錄集c中存在的aid),最終得出為:11

由此得出圖6中a右連線b的記錄=圖3公共部分記錄集c+表b記錄集b1,

最終得出的結果圖6中可以看出aid及aname非null的記錄都為圖3公共部分記錄集c中的記錄;aid及aname為null的aid為11的記錄就是表b記錄集b1中存在的bnameid。

總結:

通過上面的運算解說,相信很多人已經想到,上面的情況(包括圖3的關係圖)說明的都只是a在b的左邊的情況,

以下語句b在a的右邊的又會出現什麼情況呢??

select * from b left join a on a.aid=b.bnameid

select * from b right join a on a.aid=b.bnameid

其實對圖3左右翻轉一下就可以得出以下結論:

select * from b left join a on a.aid=b.bnameid和select * from a right join b on a.aid=b.bnameid所得出的記錄集是一樣的

而select * from b right join a on a.aid=b.bnameid和select * from a left join b on a.aid=b.bnameid所得出的記錄集也是一樣的。

你是要弄清楚區別在什麼地方還是單純想要文字說明

文字說明的樓上說了一大堆了,不說了。

弄個例題,直觀一點。兩個表:

–表stu

id name

1, jack

2, tom

3, kity

4, nono

–表exam

id grade

1, 56

2, 76

11, 89

內連線 (顯示兩表id匹配的)

select stu.id,exam.id,stu.name, exam.grade from stu inner join exam on stu.id=exam.id

stu.id exam.id name grade

--------------------------------

1 1 jack 56

2 2 tom 76

左連線(顯示join 左邊的表的所有資料,exam只有兩條記錄,所以stu.id,grade 都用null 顯示)

select stu.id,exam.id,stu.name, exam.grade from stu left join exam on stu.id=exam.id

1 1 jack 56

2 2 tom 76

3 null kity null

4 null nono null

右連線(與作連線相反,顯示join右邊表的所有資料)

select stu.id,exam.id,stu.name, exam.grade from stu right join exam on stu.id=exam.id

1 1 jack 56

2 2 tom 76

null 11 null 89

內連線與外連線的區別

1.內連線 自然連線 只有兩張表相匹配的行才能出現在結果集 2.外連線 2.1 左外連線 左邊為主表,左邊的表顯示全部 右邊為副表,右邊無符號資料時顯示null,不符合的不顯示 2.2 右外連線 右邊為主表,右邊的表顯示全部 左邊為副表,左邊無符號資料時顯示null,不符合的不顯示 2.3 全外連線...

MySQL 外連線 內連線與 連線的區別

內連線 連線的資料表相對應的匹配字段完全相等的連線。連線關鍵字是 inner join 外連線分為左外連線與右外連線 全連線。左連線的結果集包括指定的左表全部資料與匹配的右表資料,右表中沒匹配的全為空值.關鍵字 left join 右連線的結果集包含指定的右表全部資料與匹配的左邊資料,左邊中沒匹配的...

SQL內連線與外連線的區別

你是要弄清楚區別在什麼地方還是單純想要文字說明 文字說明的樓上說了一大堆了,不說了。弄個例題,直觀一點。兩個表 表stu id name 1,jack 2,tom 3,kity 4,nono 表exam id grade 1,56 2,76 11,89 內連線 顯示兩表id匹配的 select st...