圖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所得出的記錄集也是一樣的。
內連線與外連線
本篇文章只是簡單介紹一下資料庫中的內連線和外連線。舉最簡單的兩個表的例子,有表a和表b,表a如下 aid主鍵,自增 表b如下 bid主鍵,自增 有sql基本知識的人都知道,兩個表要做連線,就必須有個連線字段,從上表中的資料可以看出,在a表中的aid和b表中的bnameid就是兩個連線字段。現在先說內...
內連線與外連線
最近一段時間找工作,對以往的知識進行了複習,以下是本人對資料庫中表連線的總結 連線 連線是指將關聯式資料庫中的兩個表根據內容一定的條件連線成乙個表 連線型別 內連線與外連線 a 內連線 又稱等值連線,如 select a.b.from tablea a,tableb b where a.id b.i...
外連線與內連線
1.左外連線 select from t a a left join t b b on a.id b.id select from t a a,t b b where a.id b.id 2.右外連線 3.完全外連線 4.等值連線 我們在看看等值連線的結果 select from t a a,t b...