SQL使用------聯合查詢

聯合查詢分類

  • 內連接(inner Join 或 Join)
  • 外連接(outer Join)
  • 左外連接(left outer Join 或 left Join)
  • 右外連接(right outer Join 或 right Join)
  • 全外連接(full outer Join 或 full Join)
  • 交叉連接 (cross Join)
  • 結果集鏈接 (union 和 union all)

聯合查詢介紹

相關數據表如下:

A表
在這裏插入圖片描述
B表
在這裏插入圖片描述
C表
在這裏插入圖片描述

內連接(Inner Join)

內連接:僅顯示兩個表中匹配行,即兩表中都有才顯示。

SQL如下:

SELECT A.id AS AID, A.content AS AContent, B.id AS BID, B.content AS BContent
FROM A
       INNER JOIN B ON (A.id = B.id)

查詢結果:
在這裏插入圖片描述

由查詢結果可以看出,內連接根據連接條件(A.id=B.id)查詢出了A、B兩表中都存在的數據信息。2個表的聯合查詢結果如此,那麼3個表甚至更多表聯合查詢的結果呢?

A、B、C三表聯合內查詢SQL

SELECT A.id AS AID, A.content AS AContent, B.id AS BID, B.content AS BContent, C.id AS CID, C.content AS CContent
FROM A
       INNER JOIN B ON (A.id = B.id)
       INNER JOIN C ON (A.id = C.id)

查詢結果:
在這裏插入圖片描述

爲什麼會多了一行數據?不用驚訝,其實C表中有2個id爲1的記錄,然而我們怎麼理解得到的查詢結果呢?
可以把A、B兩表的查詢結果作爲T表(中間結果表),然後T表內連接C表,連接條件爲T.A.id=C.id

簡單來說n(n>=2)都可以看做兩張表的聯合查詢,後面的小節將只介紹兩個表的聯合查詢。

外連接(Outer Join)

左外連接(Left outer Join)

左外連接:左表有就顯示,不論右表。

SQL:

SELECT A.id AS AID, A.content AS AContent, B.id AS BID, B.content AS BContent
FROM A
       LEFT JOIN B ON (A.id = B.id)

查詢結果:
在這裏插入圖片描述

左連接並不是把B表左連接到A表上,而是把A表作爲基準表。由查詢結果可以看出,A、B兩表左連接,只要A中有結果,無論B表中有無結果,都會被查詢出來。

右外連接(Right outer Join)

右外連接:右表有就顯示,不論左表。

SQL:

SELECT A.id AS AID, A.content AS AContent, B.id AS BID, B.content AS BContent
FROM A
       RIGHT JOIN B ON (A.id = B.id)

查詢結果:
在這裏插入圖片描述

右連接和左連接類似,只是把B表(連接的表)作爲基準表。由查詢結果可以看出,無論A表是否存在其他數據,只要B表數據存在就會被查詢出來。

全外連接(Full outer Join)

全外連接:左表/右表,有一個有就顯示。

SQL:

SELECT
    A.id AS AID,
    A.content AS AContent,
    B.id AS BID,
    B.content AS BContent
FROM
    A
FULL JOIN B ON (A.id = B.id);

查詢結果:
在這裏插入圖片描述

全外連接查詢就字面意思也不難看出是查詢出兩表(A、B)中的所有記錄信息。
注:MySQL中不支持全外連接(但是可以union來實現,後面會介紹)。

交叉連接(Cross Join)

SQL:

SELECT A.id AS AID, A.content AS AContent, B.id AS BID, B.content AS BContent
FROM A
       CROSS JOIN B

查詢結果:
在這裏插入圖片描述

由結果可以看出,交叉連接是對A、B量表進行笛卡爾積的結果查詢出來。即A的每條記錄都有和B中所有記錄相對應的信息。

SQL Union

SQL Union用於將多個select結果集進行合併。值得注意的是,UNION 內部的 SELECT 語句必須擁有相同數量的列。列也必須擁有相似的數據類型。同時,每條 SELECT 語句中的列的順序必須相同。

SQL:

SELECT * FROM A UNION SELECT * from B

查詢結果:
在這裏插入圖片描述

Union是把2個Select結果集進行合併,由查詢結果也不難看出,A、B兩表的結果數據進行了合併,並且都被查詢出來了。
如果2個Select結果集中存在相同的結果,用Union則會把相同的記錄進行合併,查詢結果中僅僅會顯示一條。那麼如果想都顯示出來,把Union換成Union All 即可。

Union實現Full outer Join:

首先獲取A、B表中id的不同組合。

SQL:

CREATE VIEW v as SELECT A.id
                 from A
                 UNION SELECT B.id
                       from B

視圖內存如下:
在這裏插入圖片描述

以視圖V爲基本表,Left Join A、B表即可。

SQL:

SELECT A.id, A.content, B.id, B.content
FROM v
       LEFT JOIN A ON (A.id = v.id)
       LEFT JOIN B ON (B.id = v.id)

查詢結果如下:
在這裏插入圖片描述

發表評論
所有評論
還沒有人評論,想成為第一個評論的人麼? 請在上方評論欄輸入並且點擊發布.
相關文章