關(guān)系型數(shù)據(jù)庫最難的地方,就是建模(model)。
錯(cuò)綜復(fù)雜的數(shù)據(jù),需要建立模型,才能儲(chǔ)存在數(shù)據(jù)庫。所謂"模型"就是兩樣?xùn)|西:實(shí)體(entity)+ 關(guān)系(relationship)。
實(shí)體指的是那些實(shí)際的對(duì)象,帶有自己的屬性,可以理解成一組相關(guān)屬性的容器。關(guān)系就是實(shí)體之間的聯(lián)系,通常可以分成"一對(duì)一"、"一對(duì)多"和"多對(duì)多"等類型。
在關(guān)系型數(shù)據(jù)庫里面,每個(gè)實(shí)體有自己的一張表(table),所有屬性都是這張表的字段(field),表與表之間根據(jù)關(guān)聯(lián)字段"連接"(join)在一起。所以,表的連接是關(guān)系型數(shù)據(jù)庫的核心問題。
表的連接分成好幾種類型。
內(nèi)連接(inner join)
外連接(outer join)
左連接(left join)
右連接(right join)
全連接(full join)
以前,很多文章采用維恩圖(兩個(gè)圓的集合運(yùn)算),解釋不同連接的差異。
上周,我讀到一篇文章,認(rèn)為還有比維恩圖更好的解釋方式。我發(fā)現(xiàn)確實(shí)如此,換一個(gè)角度解釋,更容易懂。
所謂"連接",就是兩張表根據(jù)關(guān)聯(lián)字段,組合成一個(gè)數(shù)據(jù)集。問題是,兩張表的關(guān)聯(lián)字段的值往往是不一致的,如果關(guān)聯(lián)字段不匹配,怎么處理?比如,表 A 包含張三和李四,表 B 包含李四和王五,匹配的只有李四這一條記錄。
很容易看出,一共有四種處理方法。
只返回兩張表匹配的記錄,這叫內(nèi)連接(inner join)。
返回匹配的記錄,以及表 A 多余的記錄,這叫左連接(left join)。
返回匹配的記錄,以及表 B 多余的記錄,這叫右連接(right join)。
返回匹配的記錄,以及表 A 和表 B 各自的多余記錄,這叫全連接(full join)。
下圖就是四種連接的圖示。我覺得,這張圖比維恩圖更易懂,也更準(zhǔn)確。
上圖中,表 A 的記錄是 123,表 B 的記錄是 ABC,顏色表示匹配關(guān)系。返回結(jié)果中,如果另一張表沒有匹配的記錄,則用 null 填充。
這四種連接,又可以分成兩大類:內(nèi)連接(inner join)表示只包含匹配的記錄,外連接(outer join)表示還包含不匹配的記錄。所以,左連接、右連接、全連接都屬于外連接。
這四種連接的 SQL 語句如下。
SELECT*FROMAINNERJOINBONA.book_id=B.book_id;SELECT*FROMALEFTJOINBONA.book_id=B.book_id;SELECT*FROMARIGHTJOINBONA.book_id=B.book_id;SELECT*FROMAFULLJOINBONA.book_id=B.book_id;
上面的 SQL 語句還可以加上where條件從句,對(duì)記錄進(jìn)行篩選,比如只返回表 A 里面不匹配表 B 的記錄。
SELECT*FROMALEFTJOINBONA.book_id=B.book_idWHEREB.idISnull;
另一個(gè)例子,返回表 A 或表 B 所有不匹配的記錄。
SELECT*FROMAFULLJOINBONA.book_id=B.book_idWHEREA.idISnullORB.idISnull;
此外,還存在一種特殊的連接,叫做"交叉連接"(cross join),指的是表 A 和表 B 不存在關(guān)聯(lián)字段,這時(shí)表 A(共有 n 條記錄)與表 B (共有 m 條記錄)連接后,會(huì)產(chǎn)生一張包含 n x m 條記錄的新表(見下圖)。
-
SQL
+關(guān)注
關(guān)注
1文章
775瀏覽量
44272 -
數(shù)據(jù)庫
+關(guān)注
關(guān)注
7文章
3852瀏覽量
64727 -
數(shù)據(jù)集
+關(guān)注
關(guān)注
4文章
1209瀏覽量
24848
原文標(biāo)題:數(shù)據(jù)庫表連接的簡(jiǎn)單解釋
文章出處:【微信號(hào):DBDevs,微信公眾號(hào):數(shù)據(jù)分析與開發(fā)】歡迎添加關(guān)注!文章轉(zhuǎn)載請(qǐng)注明出處。
發(fā)布評(píng)論請(qǐng)先 登錄
相關(guān)推薦
HarmonyOS開發(fā)案例:【關(guān)系型數(shù)據(jù)庫】
![HarmonyOS開發(fā)案例:【<b class='flag-5'>關(guān)系</b><b class='flag-5'>型</b><b class='flag-5'>數(shù)據(jù)庫</b>】](https://file1.elecfans.com/web2/M00/D1/22/wKgaomYiW9GAOVkxAMBLtvnlUVM543.jpg)
HarmonyOS開發(fā)案例:【搭建關(guān)系型數(shù)據(jù)庫】(4)
![HarmonyOS開發(fā)案例:【搭建<b class='flag-5'>關(guān)系</b><b class='flag-5'>型</b><b class='flag-5'>數(shù)據(jù)庫</b>】(4)](https://file1.elecfans.com/web2/M00/E3/F9/wKgZomY-EPeAaulNAAB1Spd11Tg359.jpg)
關(guān)系型數(shù)據(jù)庫與非關(guān)系數(shù)據(jù)庫的區(qū)別淺析
HarmonyOS關(guān)系型數(shù)據(jù)庫和對(duì)象關(guān)系數(shù)據(jù)庫的使用方法
什么是關(guān)系型數(shù)據(jù)庫
什么是非關(guān)系型數(shù)據(jù)庫
hbase和關(guān)系型數(shù)據(jù)庫的區(qū)別
![hbase和<b class='flag-5'>關(guān)系</b><b class='flag-5'>型</b><b class='flag-5'>數(shù)據(jù)庫</b>的區(qū)別](https://file1.elecfans.com//web2/M00/A7/1E/wKgZomUMQnyAGntMAAAbXy3Bht0436.jpg)
關(guān)系型數(shù)據(jù)庫表結(jié)構(gòu)的設(shè)計(jì)有什么技巧??jī)蓚€(gè)設(shè)計(jì)技巧詳細(xì)說明
基于SQLite的鴻蒙的關(guān)系型數(shù)據(jù)庫使用
![基于SQLite的鴻蒙的<b class='flag-5'>關(guān)系</b><b class='flag-5'>型</b><b class='flag-5'>數(shù)據(jù)庫</b>使用](https://file.elecfans.com/web1/M00/DB/BC/pIYBAGAHp26AaK2FAAE3c435YvM771.png)
輕松設(shè)計(jì)關(guān)系型數(shù)據(jù)庫教程
【數(shù)據(jù)庫數(shù)據(jù)恢復(fù)】MySQL數(shù)據(jù)庫Delete誤刪除的數(shù)據(jù)恢復(fù)案例
![【<b class='flag-5'>數(shù)據(jù)庫</b><b class='flag-5'>數(shù)據(jù)</b>恢復(fù)】MySQL<b class='flag-5'>數(shù)據(jù)庫</b>Delete誤刪除的<b class='flag-5'>數(shù)據(jù)</b>恢復(fù)案例](https://file.elecfans.com//web2/M00/81/92/pYYBAGOQDUWAJzYjAACGo8m01mQ405.jpg)
OpenHarmony關(guān)系型數(shù)據(jù)庫概述
![OpenHarmony<b class='flag-5'>關(guān)系</b><b class='flag-5'>型</b><b class='flag-5'>數(shù)據(jù)庫</b>概述](https://file1.elecfans.com/web2/M00/81/ED/wKgZomQivFyAP7pkAACcKWbjBNk002.png)
評(píng)論