天天看點

SQL使用(一)-----聯合查詢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表

SQL使用(一)-----聯合查詢SQL使用(一)——聯合查詢

B表

SQL使用(一)-----聯合查詢SQL使用(一)——聯合查詢

C表

SQL使用(一)-----聯合查詢SQL使用(一)——聯合查詢

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)
           

查詢結果:

SQL使用(一)-----聯合查詢SQL使用(一)——聯合查詢
由查詢結果可以看出,内連接配接根據連接配接條件(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)
           

查詢結果:

SQL使用(一)-----聯合查詢SQL使用(一)——聯合查詢

啊?怎麼多了一行資料?不用驚訝,其實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);
           

查詢結果:

SQL使用(一)-----聯合查詢SQL使用(一)——聯合查詢
左連接配接并不是把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);
           

查詢結果:

SQL使用(一)-----聯合查詢SQL使用(一)——聯合查詢
右連接配接和左連接配接類似,隻是把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);
           

查詢結果:

SQL使用(一)-----聯合查詢SQL使用(一)——聯合查詢

全外連接配接查詢就字面意思也不難看出是查詢出兩表(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;
           

查詢結果:

SQL使用(一)-----聯合查詢SQL使用(一)——聯合查詢
由結果可以看出,交叉連接配接是對A、B量表進行笛卡爾積的結果查詢出來。即A的每條記錄都有和B中所有記錄相對應的資訊。

2.3 SQL Union

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

SQL:

查詢結果:

SQL使用(一)-----聯合查詢SQL使用(一)——聯合查詢

Union是把2個Select結果集進行合并,由查詢結果也不難看出,A、B兩表的結果資料進行了合并,并且都被查詢出來了。

如果2個Select結果集中存在相同的結果,用Union則會把相同的記錄進行合并,查詢結果中僅僅會顯示一條。那麼如果想都顯示出來,把Union換成Union All 即可。

Union實作Full outer Join:

1.首先擷取A、B表中id的不同組合。

SQL:

視圖記憶體如下:

SQL使用(一)-----聯合查詢SQL使用(一)——聯合查詢

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);
           

查詢結果如下:

SQL使用(一)-----聯合查詢SQL使用(一)——聯合查詢

參考材料:

w3cschool

http://www.cnblogs.com/liuyifan/p/4985512.html

http://blog.sina.com.cn/s/blog_4b5e75c60101i0yq.html