外連接分為左外連接,右外連接以及全外連接。前面我們學習的
內連接獲得是滿足條件的記錄,連接查詢的表中不滿足條件的記錄被去掉。而外連接的特點是:查詢出的結果存在不滿足條件的可能。
1.左外連接
左外連接是將左表的所有記錄查詢出來,左表中不滿足條件的記錄對應的右表中的列的值顯示為NULL。左外連接的關鍵詞是:LEFT OUTER JOIN,對應的sql語句如下:
- SELECT * FROM 表1 別名1 LEFT OUTER JOIN 表2 別名2 ON 別名1.列名=別名2.列名
其中表1就是左表,又稱為主表,表2是右表。
使用左外連接查詢出每個員工的信息以及所在部門信息,對應的查詢語句是:select * from emp e left outer join dept d on e.deptno=d.deptno,查詢結果如圖1-1所示:
圖1-1 左外連接
圖1-1中,由查詢結果可知當左表的記錄不滿足條件時,右表的列的值為null。圖1-1中張三的部門號為50,而dept表中沒有這個部門,那么部門信息就用null代替。這就是左外連接的特點。
2.右外連接
右外連接是將右表中的所有記錄查詢出來,右表中不滿足條件的記錄對應的左表中的列的值顯示為NULL。右連接的關鍵詞是:RIGHT OUTER JOIN,對應的sql語句如下:
- SELECT * FROM 表1 別名1 RIGHT OUTER JOIN 表2 別名2 ON 別名1.列名=別名2.列名
其中表1是左表,表2是右表,又稱為主表。
使用右外連接查詢出每個部門的信息,以及部門的員工信息,對應的查詢語句是:select * from emp e right outer join dept d on e.deptno=d.deptno,查詢結果如圖1-2所示:
圖1-2 右外連接
圖1-1中,查詢的結果中財務部沒有員工,那么必然不會有員工的部門號與財務部的部門號相同,那么該記錄就不滿足查詢條件,因此左表的所有列的值為null,這就是右外連接的特點。
3.全外連接
全外連接對左表和右表都不做限制,所有的記錄都顯示,兩表中不滿足條件的地方用null填充。全外連接的關鍵詞是:FULL OUTRE JOIN,對應的sql語句如下:
- SELECT * FROM 表1 別名1 FULL OUTER JOIN 表2 別名2 ON 別名1.列名=別名2.列名
MySQL數據庫不支持全外連接,但是從分析來看,全外連接就是將左外連接以及右外連接的結果合并起來。
使用全外連接查詢emp表和dept表的信息,如圖1-3所示:
圖1-3 全外連接
圖1-3中,使用如下sql語句模擬全外連接的效果:
SELECT
*
FROM
emp e LEFT OUTER JOIN dept d
ON
e.deptno=d.deptno
UNION
SELECT
*
FROM
emp e RIGHT OUTER JOIN dept d
ON
e.deptno=d.deptno
圖1-3的查詢結果中,兩個表中不滿足條件的對應位置用null代替。
使用左外連接查詢,左表是e1,因此e1表中的所有員工姓名都被查詢出來,e2表中不滿足條件的位置用null代替。
本文版權歸傳智播客Java培訓學院所有,歡迎轉載,轉載請注明作者出處。謝謝!
作者:傳智播客Java培訓學院
首發:http://www.itcast.cn/javaee