|
|
茫茫網海中的冷日
發生過的事,不可能遺忘,只是想不起來而已! |
|
恭喜您是本站第 1729846
位訪客!
登入 | 註冊
|
|
|
|
發表者 |
討論內容 |
冷日 (冷日) |
發表時間:2012/11/13 7:45 |
- Webmaster

- 註冊日: 2008/2/19
- 來自:
- 發表數: 15773
|
- [轉貼][MySQL]left, right, inner, outer join 使用方法
- [MySQL]left, right, inner, outer join 使用方法
Jan 24th, 2009 by appleboy
最近在高雄面試的時候,被問到的資料庫問題,什麼是 left join,out join,inner join,其實這些都是寫基本 SQL 語法需要知道的,當然我比較少用到 out join,不過還是要知道一下比較好喔,底下來說明一下這些,整理一些心得
表格 test1 資料表

表格 test2 資料表

首先大概是了解 inner 跟 outer 的差別,初學者大概都會使用 inner 這也是我們常常在用的 SQL,inner 就是 join 兩個資料表只顯示匹對的資料,另外一種 outer 就是不管是否有匹對,都會將資料顯示出來,又分為 LEFT, RIGHT, FULL join。
join 總共分為六種
Inner Join
Natural Join
Left Outer Join
Right Outer Join
Full Outer Join
Cross Join
1. Inner Join -- -- 這算是最普通的 join 方法 --
SELECT a.*, b.* FROM `test1` AS a, `test2` AS b WHERE a.id = b.id
2. Natural Join -- -- 利用兩資料表相同欄位,自動連接上 --
SELECT a.*, b.* FROM `test1` AS a NATURAL JOIN `test2` AS b
3. Left, Right join -- -- 這兩個其實是相同的,left join 就是顯示左邊表格所有資料,如果匹對沒有的話,就是顯示 NULL right 則是相反 --
SELECT a.*, b.* FROM `test1` AS a LEFT JOIN `test2` AS b ON a.id = b.id
4. Full Outer Join 這個可以利用 SQL UNION 處理掉,這只是聯集 Left 跟 Right
5. Cross Join 在 MySQL 語法裡面,它相同於 INNER Join,但是在標準 SQL 底下,它們不盡相同
SELECT * FROM t1 LEFT JOIN (t2, t3, t4) ON (t2.a=t1.a AND t3.b=t1.b AND t4.c=t1.c)
同等於
SELECT * FROM t1 LEFT JOIN (t2 CROSS JOIN t3 CROSS JOIN t4) ON (t2.a=t1.a AND t3.b=t1.b AND t4.c=t1.c)
取一段 MySQL 官網的文字:
In MySQL, CROSS JOIN is a syntactic equivalent to INNER JOIN (they can replace each other).
In standard SQL, they are not equivalent.
INNER JOIN is used with an ON clause, CROSS JOIN is used otherwise.
原文出處:[MySQL]left, right, inner, outer join 使用方法 | 小惡魔 - 電腦技術 - 工作筆記 - AppleBOY
|
|
|
討論串
-
[轉貼]MSSQL Join總結 (冷日 (冷日), 2010/10/23 12:21)
-
[轉貼][MySQL] outer join 使用 (冷日 (冷日), 2012/11/13 7:40)
- »
[轉貼][MySQL]left, right, inner, outer join 使用方法 (冷日 (冷日), 2012/11/13 7:45)
-
[分享]一些來自 MySql 官網上的討論範例,超實用! (冷日 (冷日), 2012/11/13 8:08)
-
[轉貼]Oracle PL/SQL SELECT 的 OUT JOIN (+) 用法 (冷日 (冷日), 2016/9/14 9:50)
-
[轉貼]SQL Join 的觀念 (冷日 (冷日), 2018/12/12 4:57)
-
[轉貼]SQL inner join、full out join、left join 的觀念 (冷日 (冷日), 2018/12/12 5:01)
|