标签:
假设我们有两张表。
其各有四条记录,其中有两条记录是相同的,如下所示:
id name id name
1 Pirate 1 Rutabaga
2 Monkey 2 Pirate
3 Ninja 3 Darth Vader
4 Spaghetti 4 Ninja
下面让我们来看看不同的Join会产生什么样的结果。
1、Inner join
SELECT * FROM TableA INNER JOIN TableB ON TableA.name = TableB.name
结果集
(TableA.) (TableB.)
id name id name
1 Pirate 2 Pirate
3 Ninja 4 Ninja
Inner join 产生的结果集中,是A和B的交集
2.FULL [OUTER] JOIN
SELECT * FROM TableA FULL OUTER JOIN TableB ON TableA.name = TableB.name
id name id name
1 Pirate 2 Pirate
2 Monkey null null
3 Ninja 4 Ninja
4 Spaghetti null null
null null 1 Rutabaga
null null 3 Darth Vader
id name id name
1 Pirate 2 Pirate
2 Monkey null null
3 Ninja 4 Ninja
4 Spaghetti null null
注意:产生在A表中有而在B表中没有的集合
SELECT * FROM TableA LEFT OUTER JOIN TableB ON TableA.name = TableB.name
WHERE TableB.id IS null
(TableA.) (TableB.)
id name id name
2 Monkey null null
4 Spaghetti null null
4、UNION 与 UNION ALL
UNION 内部的 SELECT 语句必须拥有相同数量的列。列也必须拥有相似的数据类型
UNION 只选取记录,会选取不同的值;而UNION ALL会列出所有记录,包括重复的
标签:
原文地址:http://www.cnblogs.com/tiandi/p/5372982.html