1. 程式人生 > >inner join on, left join on, right join on講解

inner join on, left join on, right join on講解

inner join on, left join on, right join on講解

1.理論

只要兩個表的公共欄位有匹配值,就將這兩個表中的記錄組合起來。

個人理解:以一個共同的欄位求兩個表中符合要求的交集,並將每個表符合要求的記錄以共同的欄位為牽引合併起來。

語法

FROM table1 INNER JOIN table2 ON table1 . field1 compopr table2 . field2

INNER JOIN 操作包含以下部分:

部分 說明

table1, table2 要組合其中的記錄的表的名稱。

field1,field2 要聯接的欄位的名稱。如果它們不是數字,則這些欄位的資料型別必須相同,並且包含同類資料,但是,它們不必具有相同的名稱。

compopr 任何關係比較運算子:“=”、“<”、“>”、“<=”、“>=”或者“<>”。

說明

可以在任何 FROM 子句中使用 INNER JOIN 操作。這是最常用的聯接型別。只要兩個表的公共欄位上存在相匹配的值,Inner 聯接就會組合這些表中的記錄。

可以將 INNER JOIN 用於 Departments 及 Employees 表,以選擇出每個部門的所有僱員。而要選擇所有部分(即使某些部門中並沒有被分配僱員)或者所有僱員(即使某些僱員沒有分配到任何部門),則可以通過 LEFT JOIN 或者 RIGHT JOIN 操作來建立外部聯接。

如果試圖聯接包含備註或 OLE 物件資料的欄位,將發生錯誤。

可以聯接任何兩個相似型別的數字欄位。例如,可以聯接自動編號和長整型欄位,因為它們均是相似型別。然而,不能聯接單精度型和雙精度型型別欄位。

下例展示瞭如何通過 CategoryID 欄位聯接 Categories 和 Products 表:

SELECT CategoryName, ProductName

FROM Categories INNER JOIN Products

ON Categories.CategoryID = Products.CategoryID;

在前面的示例中,CategoryID 是被聯接欄位,但是它不包含在查詢輸出中,因為它不包含在 SELECT 語句中。若要包含被聯接欄位,請在 SELECT 語句中包含該欄位名,在本例中是指 Categories.CategoryID。

也可以在 JOIN 語句中連結多個 ON 子句,請使用如下語法:

SELECT fields

FROM table1 INNER JOIN table2

ON table1.field1 compopr table2.field1 AND

ON table1.field2 compopr table2.field2) OR

ON table1.field3 compopr table2.field3)];

也可以通過如下語法巢狀 JOIN 語句:

SELECT fields

FROM table1 INNER JOIN

(table2 INNER JOIN [( ]table3

[INNER JOIN [( ]tablex [INNER JOIN ...)] 

ON table3.field3 compopr tablex.fieldx)]

ON table2.field2 compopr table3.field3) 

ON table1.field1 compopr table2.field2;

LEFT JOIN 或 RIGHT JOIN 可以巢狀在 INNER JOIN 之中,但是 INNER JOIN 不能巢狀於 LEFT JOIN 或 RIGHT JOIN 之中。

2.操作例項

表A記錄如下:

aID aNum

1 a20050111

2 a20050112

3 a20050113

4 a20050114

5 a20050115

表B記錄如下:

bID bName

1 2006032401

2 2006032402

3 2006032403

4 2006032404

8 2006032408

實驗如下:

1.left join

sql語句如下: 

select * from A

left join B 

on A.aID = B.bID

結果如下:

aID aNum bID bName

1 a20050111 1 2006032401

2 a20050112 2 2006032402

3 a20050113 3 2006032403

4 a20050114 4 2006032404

5 a20050115 NULL NULL

(所影響的行數為 5 行)

結果說明:

left join是以A表的記錄為基礎的,A可以看成左表,B可以看成右表,left join是以左表為準的.

換句話說,左表(A)的記錄將會全部表示出來,而右表(B)只會顯示符合搜尋條件的記錄(例子中為: A.aID = B.bID).

B表記錄不足的地方均為NULL.

2.right join

sql語句如下: 

select * from A

right join B 

on A.aID = B.bID

結果如下:

aID aNum bID bName

1 a20050111 1 2006032401

2 a20050112 2 2006032402

3 a20050113 3 2006032403

4 a20050114 4 2006032404

NULL NULL 8 2006032408

(所影響的行數為 5 行)

結果說明:

仔細觀察一下,就會發現,和left join的結果剛好相反,這次是以右表(B)為基礎的,A表不足的地方用NULL填充.

3.inner join

sql語句如下: 

select * from A

innerjoin B 

on A.aID = B.bID

結果如下:

aID aNum bID bName

1 a20050111 1 2006032401

2 a20050112 2 2006032402

3 a20050113 3 2006032403

4 a20050114 4 2006032404

結果說明:

很明顯,這裡只顯示出了 A.aID = B.bID的記錄.這說明inner join並不以誰為基礎,它只顯示符合條件的記錄.