国产 无码 综合区,色欲AV无码国产永久播放,无码天堂亚洲国产AV,国产日韩欧美女同一区二区

SQL連接的理解和使用(內(nèi)連接:自然連接&等值連接,外連接:左連接&右連接&全外連接)

這篇具有很好參考價(jià)值的文章主要介紹了SQL連接的理解和使用(內(nèi)連接:自然連接&等值連接,外連接:左連接&右連接&全外連接)。希望對(duì)大家有所幫助。如果存在錯(cuò)誤或未考慮完全的地方,請(qǐng)大家不吝賜教,您也可以點(diǎn)擊"舉報(bào)違法"按鈕提交疑問(wèn)。

一、連接的介紹

連接是什么?

連接(Join)是指將兩個(gè)或多個(gè)表中的數(shù)據(jù)按照一定的條件關(guān)聯(lián)起來(lái),形成一個(gè)新的虛擬表。也可以理解為兩個(gè)表的笛卡爾積中篩選符合條件的行。

什么是笛卡爾積?
數(shù)據(jù)庫(kù)自然連接,測(cè)試工具,數(shù)據(jù)庫(kù),sql,數(shù)據(jù)庫(kù),mysql
圖中名詞解析:
元素:集合中{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è)域;
數(shù)據(jù)庫(kù)自然連接,測(cè)試工具,數(shù)據(jù)庫(kù),sql,數(shù)據(jù)庫(kù),mysql

連接分幾種?

三種類型:條件連接、等值連接、自然連接

條件連接

條件連接又稱為θ連接
定義:多個(gè)表的笛卡爾積中選取滿足條件的行的連接(定義和連接定義一樣,連接不分家)
舉例:select * from R,S where R.A < S.B 有條件的查詢
1.現(xiàn)將R和S的笛卡爾積列出(R x S 中的x是笛卡爾積的集合運(yùn)算符)
數(shù)據(jù)庫(kù)自然連接,測(cè)試工具,數(shù)據(jù)庫(kù),sql,數(shù)據(jù)庫(kù),mysql
2.篩選出符合R.A < S.B的條件的行,除去圈出的部分其余都是符合R.A < S.B條件,即生成一張新的虛擬表(?表示連接運(yùn)算符)
數(shù)據(jù)庫(kù)自然連接,測(cè)試工具,數(shù)據(jù)庫(kù),sql,數(shù)據(jù)庫(kù),mysql

等值連接

等值連接又稱為逗號(hào)連接
定義:特殊的條件連接,當(dāng)條件連接的條件為“=”時(shí),稱為等值連接
舉例:

select * from R,S where R.A = S.A 

如圖中圈出的兩行則是SQL查詢出來(lái)的數(shù)據(jù)
數(shù)據(jù)庫(kù)自然連接,測(cè)試工具,數(shù)據(jù)庫(kù),sql,數(shù)據(jù)庫(kù),mysql

自然連接

定義:特殊的等值連接,要求多個(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

數(shù)據(jù)庫(kù)自然連接,測(cè)試工具,數(shù)據(jù)庫(kù),sql,數(shù)據(jù)庫(kù),mysql

二、連接的使用

通過(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。

以下是原始表
數(shù)據(jù)庫(kù)自然連接,測(cè)試工具,數(shù)據(jù)庫(kù),sql,數(shù)據(jù)庫(kù),mysql

左連接 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é)果:
數(shù)據(jù)庫(kù)自然連接,測(cè)試工具,數(shù)據(jù)庫(kù),sql,數(shù)據(jù)庫(kù),mysql

右連接 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é)果:
數(shù)據(jù)庫(kù)自然連接,測(cè)試工具,數(shù)據(jù)庫(kù),sql,數(shù)據(jù)庫(kù),mysql

全外連接 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é)果:
數(shù)據(jù)庫(kù)自然連接,測(cè)試工具,數(shù)據(jù)庫(kù),sql,數(shù)據(jù)庫(kù),mysql

外連接規(guī)則

左連右補(bǔ),右連左補(bǔ),全連左右合并
菜鳥(niǎo)教程的圖解
數(shù)據(jù)庫(kù)自然連接,測(cè)試工具,數(shù)據(jù)庫(kù),sql,數(shù)據(jù)庫(kù),mysql文章來(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)!

本文來(lái)自互聯(lián)網(wǎng)用戶投稿,該文觀點(diǎn)僅代表作者本人,不代表本站立場(chǎng)。本站僅提供信息存儲(chǔ)空間服務(wù),不擁有所有權(quán),不承擔(dān)相關(guān)法律責(zé)任。如若轉(zhuǎn)載,請(qǐng)注明出處: 如若內(nèi)容造成侵權(quán)/違法違規(guī)/事實(shí)不符,請(qǐng)點(diǎn)擊違法舉報(bào)進(jìn)行投訴反饋,一經(jīng)查實(shí),立即刪除!

領(lǐng)支付寶紅包贊助服務(wù)器費(fèi)用

相關(guān)文章

覺(jué)得文章有用就打賞一下文章作者

支付寶掃一掃打賞

博客贊助

微信掃一掃打賞

請(qǐng)作者喝杯咖啡吧~博客贊助

支付寶掃一掃領(lǐng)取紅包,優(yōu)惠每天領(lǐng)

二維碼1

領(lǐng)取紅包

二維碼2

領(lǐng)紅包