SQL使用(一)-----聯合查詢
SQL使用(一)——聯合查詢
1.聯合查詢分類
- 內連線(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)
2.聯合查詢介紹
相關資料表如下:
A表
B表
C表
2.1內連線(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)都可以看做兩張表的聯合查詢,後面的小節將只介紹兩個表的聯合查詢。
2.2外連線(Outer Join)
2.2.1左外連線(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表中有無結果,都會被查詢出來。
2.2.2右外連線(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表資料存在就會被查詢出來。
2.2.3全外連線(Full outer Join)
全外連線:左表/右表,有一個有就顯示。
SQL:
SELECT
A.id AS AID,
A.content AS AContent,
B.id AS BID,
B.content AS BContent
FROM
A
FULL OUTER JOIN B ON (A.id = B.id);
查詢結果:
全外連線查詢就字面意思也不難看出是查詢出兩表(A、B)中的所有記錄資訊。
注:MySQL中不支援全外連線(但是可以union來實現,後面會介紹)。
2.2交叉連線(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中所有記錄相對應的資訊。
2.3 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:
1.首先獲取A、B表中id的不同組合。
SQL:
CREATE VIEW v as SELECT A.id from A UNION SELECT B.id from B;
檢視記憶體如下:
2.以檢視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);
查詢結果如下: