JOIN ,LEFT JOIN ,ALL JOIN 等的區別和聯系


left join(左聯接) 返回包括左表中的所有記錄和右表中聯結字段相等的記錄 
right join(右聯接) 返回包括右表中的所有記錄和左表中聯結字段相等的記錄
inner join(等值連接) 只返回兩個表中聯結字段相等的行
 
舉例如下: 
--------------------------------------------
表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並不以誰為基礎,它只顯示符合條件的記錄.
--------------------------------------------
注: 
LEFT JOIN操作用於在任何的 FROM 子句中,組合來源表的記錄。使用 LEFT JOIN 運算來創建一個左邊外部聯接。左邊外部聯接將包含了從第一個(左邊)開始的兩個表中的全部記錄,即使在第二個(右邊)表中並沒有相符值的記錄。
 
語法:FROM table1 LEFT JOIN table2 ON table1.field1 compopr table2.field2
 
說明:table1, table2參數用於指定要將記錄組合的表的名稱。
field1, field2參數指定被聯接的字段的名稱。且這些字段必須有相同的數據類型及包含相同類型的數據,但它們不需要有相同的名稱。
compopr參數指定關系比較運算符:"=", "<", ">", "<=", ">=" 或 "<>"。
如果在INNER JOIN操作中要聯接包含Memo 數據類型或 OLE Object 數據類型數據的字段,將會發生錯誤.

 

 

Select  a.*  From  inner  join  on  a.id=b.id
--這個就是a和b中都存在的id才會顯示出來
Select  a.*,b.*  From  left  outer  join  on  a.id=b.id
--如果是left 的話就是a的id如果在b中不存在,那么可以顯示 如果b的在a的中沒有就不顯示b的內容,他的內容都是null,Right outer JOin相反
Select  a.*,b.*  from  Full  Outer  Join  On  a.id=b.id
--想當與包含了left outer join 和 Right Outer Join 就是只要a和b里面存在的id都會出現 如果a的id沒有在b中則b的內容為null,反之相同

 

 

Join  表示兩個表都必須存在的
left join 表示以左邊的表為基准,不管你右邊的表有沒有都顯示
right join和left join剛好相反
full outer join表示只要在兩個表中任何一個表中有的都顯示 

 

inner join 內連接
left join  左連接  左邊的表為主表,數據完全存在(right join 右連接就是left join的主對象表換過來)
full join  相當於  left join + right join
cross join 笛卡爾集合 

 

inner join 內連接 
left join  左連接  左邊的表為主表,數據完全存在 
right join 右連接  右邊表為主表,

full join  相當於  left join + right join  

JOIN:內連
LEFT JOIN:左連(左邊的數據一值有) 


免責聲明!

本站轉載的文章為個人學習借鑒使用,本站對版權不負任何法律責任。如果侵犯了您的隱私權益,請聯系本站郵箱yoyou2525@163.com刪除。



 
粵ICP備18138465號   © 2018-2025 CODEPRJ.COM