一、連接的介紹
連接是什么?
連接(Join)是指將兩個(gè)或多個(gè)表中的數(shù)據(jù)按照一定的條件關(guān)聯(lián)起來(lái),形成一個(gè)新的虛擬表。也可以理解為兩個(gè)表的笛卡爾積中篩選符合條件的行。
什么是笛卡爾積?
圖中名詞解析:
元素:集合中{d1,d2},每一個(gè)值稱為一個(gè)元素,如:d1是一個(gè)元素;在表中表示每一行;
元組:一個(gè)元素就是一個(gè)元組,所以集合{d1,d2}中有2個(gè)元組,一個(gè)元組在數(shù)據(jù)表中指的是一行數(shù)據(jù);
分量:一個(gè)元組里的每一個(gè)值,如:元組d1的數(shù)據(jù)是[張三,24,湖北]
,那么張三就是一個(gè)分量;
域:每一列數(shù)據(jù)稱為一個(gè)域,如:元組d1的數(shù)據(jù)是[張三,24,湖北]
,元組d2的數(shù)據(jù)是[李三,25,湖南]
,那么 張三,李三 就是一個(gè)域;
連接分幾種?
三種類型:條件連接、等值連接、自然連接
條件連接
條件連接又稱為θ連接
定義:多個(gè)表的笛卡爾積中選取滿足條件的行的連接(定義和連接定義一樣,連接不分家)
舉例:select * from R,S where R.A < S.B
有條件的查詢
1.現(xiàn)將R和S的笛卡爾積列出(R x S 中的x是笛卡爾積的集合運(yùn)算符)
2.篩選出符合R.A < S.B
的條件的行,除去圈出的部分其余都是符合R.A < S.B
條件,即生成一張新的虛擬表(?表示連接運(yùn)算符)
等值連接
等值連接又稱為逗號(hào)連接
定義:特殊的條件連接,當(dāng)條件連接的條件為“=”時(shí),稱為等值連接
舉例:
select * from R,S where R.A = S.A
如圖中圈出的兩行則是SQL查詢出來(lái)的數(shù)據(jù)
自然連接
定義:特殊的等值連接,要求多個(gè)表有相同的屬性字段,條件為相同的屬性字段值相等,且再將表中重復(fù)的屬性字段去掉,稱為自然連接。
舉例:
-- natural join:自然連接,不允許帶on/using
select * from R natural join S
--上語(yǔ)句等價(jià)于下語(yǔ)句
select R.A,R.B,R.C,S.D where R.A = S.A and R.C = S.C
二、連接的使用
通過(guò)上述對(duì)連接的介紹,可以看出常使用的內(nèi)連接、左連接、右連接等都是條件連接的衍生,下面具體看看它們之間的差別及使用。
內(nèi)連接 INNER JOIN
內(nèi)連接可以稱為自然連接、等值連接
內(nèi)連接定義:從結(jié)果表中刪除與其他被連接表中沒(méi)有匹配行的所有行,所以內(nèi)連接可能會(huì)丟失信息。(對(duì)比外連接后就能明白了)
內(nèi)連接的語(yǔ)法如下:
select fieldlist from table1 [inner] join table2 on table1.column=table2.column
內(nèi)連接與等值連接區(qū)別
看定義和語(yǔ)法,是否和等值連接是那么一會(huì)事兒,其實(shí)是一回事情(等效)可以查看:https://blog.csdn.net/huanghanqian/article/details/52847835
等值連接一般用where字句設(shè)置條件,內(nèi)連接一般用on字句設(shè)置條件,但內(nèi)連接與等值連接效果是相同的。
內(nèi)連接與自然連接區(qū)別
內(nèi)連接與自然連接基本相同,不同之處在于自然連接只能是同名屬性的等值連接,而內(nèi)連接可以使用using或on子句來(lái)指定連接條件,連接條件中指出某兩字段相等(可以不同名)。
外連接 OUTER JOIN
定義:外連接的作用是將關(guān)聯(lián)查詢中不滿足關(guān)聯(lián)條件的記錄顯示在結(jié)果集中。(內(nèi)連接會(huì)丟失部分信息,外連接則補(bǔ)缺丟失部分信息)
通常我們省略outer 這個(gè)關(guān)鍵字。寫成:LEFT/RIGHT/FULL JOIN。
以下是原始表
左連接 LEFT JOIN
運(yùn)算符為:?
左外連接是將LEFT JOIN 左側(cè)的表作為主表,結(jié)果集中會(huì)包含該表所有滿足過(guò)濾條件的記錄,當(dāng)來(lái)自于LEFT JOIN 右側(cè)表的字段時(shí),不滿足連接條件的記錄值全為NULL。
舉例:
select * from table1 left join table2 on table1.c=table2.c
結(jié)果:
右連接 RIGHT JOIN
運(yùn)算符為:?
右外連接是RIGHT JOIN 右側(cè)的表作為主表,結(jié)果集中會(huì)包含該表所有滿足過(guò)濾條件的記錄,當(dāng)來(lái)自于RIGHT JOIN 左側(cè)表的字段時(shí),不滿足連接條件的記錄值全為NULL。
舉例:
select * from table1 right join table2 on table1.c=table2.c
結(jié)果:
全外連接 FULL JOIN
將左連接與右連接并集,可以達(dá)到全連接效果,UNION取并集
舉例:
select * from table1 full join table2 on table1.c=table2.c
-- 使用union的方式寫則是
select * from table1 left join table2 on table1.c=table2.c
union
select * from table1 right join table2 on table1.c=table2.c
結(jié)果:文章來(lái)源:http://www.zghlxwxcb.cn/news/detail-735577.html
外連接規(guī)則
左連右補(bǔ),右連左補(bǔ),全連左右合并
菜鳥(niǎo)教程的圖解文章來(lái)源地址http://www.zghlxwxcb.cn/news/detail-735577.html
到了這里,關(guān)于SQL連接的理解和使用(內(nèi)連接:自然連接&等值連接,外連接:左連接&右連接&全外連接)的文章就介紹完了。如果您還想了解更多內(nèi)容,請(qǐng)?jiān)谟疑辖撬阉鱐OY模板網(wǎng)以前的文章或繼續(xù)瀏覽下面的相關(guān)文章,希望大家以后多多支持TOY模板網(wǎng)!