
文章插圖
1、內(nèi)聯(lián)接(典型的聯(lián)接運(yùn)算,使用像 = 或 <> 之類的比較運(yùn)算符) 。包括相等聯(lián)接和自然聯(lián)接 。
內(nèi)聯(lián)接使用比較運(yùn)算符根據(jù)每個(gè)表共有的列的值匹配兩個(gè)表中的行 。例如,檢索 students和courses表中學(xué)生標(biāo)識(shí)號(hào)相同的所有行 。
2、外聯(lián)接 。外聯(lián)接可以是左向外聯(lián)接、右向外聯(lián)接或完整外部聯(lián)接 。
在 FROM子句中指定外聯(lián)接時(shí),可以由下列幾組關(guān)鍵字中的一組指定:
1)LEFT JOIN或LEFT OUTER JOIN
左向外聯(lián)接的結(jié)果集包括 LEFT OUTER子句中指定的左表的所有行,而不僅僅是聯(lián)接列所匹配的行 。如果左表的某行在右表中沒有匹配行,則在相關(guān)聯(lián)的結(jié)果集行中右表的所有選擇列表列均為空值 。
2)RIGHT JOIN 或 RIGHT OUTER JOIN
右向外聯(lián)接是左向外聯(lián)接的反向聯(lián)接 。將返回右表的所有行 。如果右表的某行在左表中沒有匹配行,則將為左表返回空值 。
3)FULL JOIN 或 FULL OUTER JOIN
完整外部聯(lián)接返回左表和右表中的所有行 。當(dāng)某行在另一個(gè)表中沒有匹配行時(shí),則另一個(gè)表的選擇列表列包含空值 。如果表之間有匹配行,則整個(gè)結(jié)果集行包含基表的數(shù)據(jù)值 。
3、交叉聯(lián)接
交叉聯(lián)接返回左表中的所有行,左表中的每一行與右表中的所有行組合 。交叉聯(lián)接也稱作笛卡爾積 。
FROM 子句中的表或視圖可通過內(nèi)聯(lián)接或完整外部聯(lián)接按任意順序指定;但是,用左或右向外聯(lián)接指定表或視圖時(shí),表或視圖的順序很重要 。有關(guān)使用左或右向外聯(lián)接排列表的更多信息,請(qǐng)參見使用外聯(lián)接 。
例子:
————————————————-
a表 id name b表 id job parent_id
1 張3 1 23 1
2 李四 2 34 2
3 王武 3 34 4
a.id同parent_id 存在關(guān)系
————————————————–
1) 內(nèi)連接
select a.*,b.* from a inner join b on a.id=b.parent_id
結(jié)果是
1 張3 1 23 1
2 李四 2 34 2
2)左連接
select a.*,b.* from a left join b on a.id=b.parent_id
結(jié)果是
1 張3 1 23 1
2 李四 2 34 2
3 王武 null
3) 右連接
select a.*,b.* from a right join b on a.id=b.parent_id
結(jié)果是
1 張3 1 23 1
2 李四 2 34 2
null 3 34 4
4) 完全連接
select a.*,b.* from a full join b on a.id=b.parent_id
結(jié)果是
1 張3 1 23 1
2 李四 2 34 2
null 3 34 4
3 王武 null
——————————————————————————————–
一、交叉連接(CROSS JOIN)
交叉連接(CROSS JOIN):有兩種,顯式的和隱式的,不帶ON子句,返回的是兩表的乘積,也叫笛卡爾積 。
例如:下面的語句1和語句2的結(jié)果是相同的 。
語句1:隱式的交叉連接,沒有CROSS JOIN 。
SELECT O.ID, O.ORDER_NUMBER, C.ID, C.NAME
FROM ORDERS O , CUSTOMERS C
WHERE O.ID=1;
語句2:顯式的交叉連接,使用CROSS JOIN 。
SELECT O.ID,O.ORDER_NUMBER,C.ID,
C.NAME
FROM ORDERS O CROSS JOIN CUSTOMERS C
WHERE O.ID=1;
語句1和語句2的結(jié)果是相同的,查詢結(jié)果如下:
二、內(nèi)連接(INNER JOIN)
內(nèi)連接(INNER JOIN):有兩種,顯式的和隱式的,返回連接表中符合連接條件和查詢條件的數(shù)據(jù)行 。(所謂的鏈接表就是數(shù)據(jù)庫在做查詢形成的中間表) 。
以上關(guān)于本文的內(nèi)容,僅作參考!溫馨提示:如遇健康、疾病相關(guān)的問題,請(qǐng)您及時(shí)就醫(yī)或請(qǐng)專業(yè)人士給予相關(guān)指導(dǎo)!
「愛刨根生活網(wǎng)」www.malaban59.cn小編還為您精選了以下內(nèi)容,希望對(duì)您有所幫助:- 實(shí)現(xiàn)負(fù)載均衡集的技巧 負(fù)載均衡集群如何實(shí)現(xiàn)
- mysql切換主從方法和如何使用 mysql主從切換步驟
- mysql數(shù)據(jù)庫怎么查看優(yōu)化 mysql數(shù)據(jù)庫查詢語句優(yōu)化
- 附虛擬機(jī)安裝操作教程 虛擬機(jī)安裝操作系統(tǒng)的主要步驟有哪些
- 微信關(guān)聯(lián)聊天記錄同步嗎 如何關(guān)閉附近的人
- 揭曉無法連接的原因和解決法 sql server2008連接不上服務(wù)器
- 心梗急救措施
- 故宮是哪個(gè)門都可以進(jìn)嗎?附近還有什么可玩的? 故宮哪個(gè)門進(jìn)
- 創(chuàng)建數(shù)據(jù)庫的教程 免費(fèi)mysql數(shù)據(jù)庫空間
- 代碼創(chuàng)建數(shù)據(jù)庫的步驟 sql數(shù)據(jù)庫安裝失敗怎么辦
