问题出处 http://topic.csdn.net/u/20071120/17/abf08b24-c069-4270-a4e4-4511b473b2c4.html
有2个表
表A:TA
字段
C1,C2,C3
值
a1,b1,c1
a2,b2,c2
--------------------------
表B:TB
字段(C1是表TA的外键)
C1,C4,C5
值
a1,d1,e1
a1,d2,e2
a2,d3,e3
a2,d4,e4
---------------------------
我现在想用一个查询语句查出下面的数据:
a1,b1,c1,null,null
null,null,null,d1,e1
null,null,null,d2,e2
a2,b2,c2,null,null
null,null,null,d3,e3
null,null,null,d4,e4
- WITH TA AS (
- SELECT 'A1' AS C1, 'B1' AS C2, 'C1' AS C3
- FROM DUAL
- UNION
- SELECT 'A2' AS C1, 'B2' AS C2, 'C2' AS C3 FROM DUAL
- ),
- TB AS (
- SELECT 'A1' AS C1, 'D1' AS C4, 'E1' AS C5
- FROM DUAL
- UNION
- SELECT 'A1' AS C1, 'D2' AS C4, 'E2' AS C5
- FROM DUAL
- UNION
- SELECT 'A2' AS C1, 'D3' AS C4, 'E3' AS C5
- FROM DUAL
- UNION
- SELECT 'A2' AS C1, 'D4' AS C4, 'E4' AS C5 FROM DUAL
- )
- SELECT TA.C1, TA.C2, TA.C3, TB.C4, TB.C4
- FROM TA
- FULL JOIN TB ON TA.C2 = TB.C4
- AND TA.C3 = TB.C5
外连接
left outer join 以左表为主,左表内容全显示,右表连接上的内容才显示
right outer join相反
full outer join 左右表未连接的内容全部显示
外联接。外联接可以是左向外联接、右向外联接或完整外部联接。
在 FROM 子句中指定外联接时,可以由下列几组关键字中的一组指定:
LEFT JOIN 或 LEFT OUTER JOIN。
左向外联接的结果集包括 LEFT OUTER 子句中指定的左表的所有行,而不仅仅是联接列所匹配的行。如果左表的某行在右表中没有匹配行,则在相关联的结果集行中右表的所有选择列表列均为空值。
RIGHT JOIN 或 RIGHT OUTER JOIN。
右向外联接是左向外联接的反向联接。将返回右表的所有行。如果右表的某行在左表中没有匹配行,则将为左表返回空值。
FULL JOIN 或 FULL OUTER JOIN。
完整外部联接返回左表和右表中的所有行。当某行在另一个表中没有匹配行时,则另一个表的选择列表列包含空值。如果表之间有匹配行,则整个结果集行包含基表的数据值。
仅当至少有一个同属于两表的行符合联接条件时,内联接才返回行。内联接消除与另一个表中的任何行不匹配的行。而外联接会返回 FROM 子句中提到的至少一个表或视图的所有行,只要这些行符合任何 WHERE 或 HAVING 搜索条件。将检索通过左向外联接引用的左表的所有行,以及通过右向外联接引用的右表的所有行。完整外部联接中两个表的所有行都将返回。
LEFT OUTER JOIN 或 LEFT JOIN
RIGHT OUTER JOIN 或 RIGHT JOIN
FULL OUTER JOIN 或 FULL JOIN