SQL Server中的CROSS JOIN和FULL OUTER JOIN的区别是什么?
它们是一样的吗?请解释一下。什么时候使用它们?
SQL Server中的CROSS JOIN和FULL OUTER JOIN的区别是什么?
它们是一样的吗?请解释一下。什么时候使用它们?
当前回答
交叉连接:交叉连接产生的结果由来自两个或多个表的所有行组合组成。这意味着如果表A有3行,表B有2行,那么CROSS JOIN将导致6行。这两个表之间没有建立任何关系—您实际上只是产生了每一种可能的组合。
Full outer Join:一个Full outer Join既不是“左”也不是“右”——两者都是!它包括参与JOIN的两个表或结果集中的所有行。当JOIN“左侧”的行不存在匹配行时,将看到“右侧”的结果集中的Null值。相反,当JOIN的“右侧”的行不存在匹配行时,将看到“左侧”的结果集中的Null值。
其他回答
对于某些人来说,可能不太明显的一件事是,与空表(或结果集)的交叉连接将导致空表(M x N;因此M x 0 = 0)
一个完整的外部连接总是有行,除非M和N都是0。
交叉连接:交叉连接产生的结果由来自两个或多个表的所有行组合组成。这意味着如果表A有3行,表B有2行,那么CROSS JOIN将导致6行。这两个表之间没有建立任何关系—您实际上只是产生了每一种可能的组合。
Full outer Join:一个Full outer Join既不是“左”也不是“右”——两者都是!它包括参与JOIN的两个表或结果集中的所有行。当JOIN“左侧”的行不存在匹配行时,将看到“右侧”的结果集中的Null值。相反,当JOIN的“右侧”的行不存在匹配行时,将看到“左侧”的结果集中的Null值。
SQL全外连接
FULL OUTER JOIN返回左表(table1)和右表(table2)中的所有行,而不考虑匹配情况。 FULL OUTER JOIN关键字组合了LEFT OUTER JOIN和RIGHT OUTER JOIN的结果 SQL全外部连接也称为全连接
参考资料:http://datasciencemadesimple.com/sql-full-outer-join/
SQL交叉连接
在SQL中,第一个表的每一行都映射到第二个表的每一行。 CROSS JOIN操作的结果集产生的行数等于第一个表的行数乘以第二个表的行数。 交叉连接也称为笛卡尔积/笛卡尔连接 表A的行数是m,表B的行数是n,结果表将有m*n行
参考:http://datasciencemadesimple.com/sql-cross-join/
交叉加入:http://www.dba-oracle.com/t_garmany_9_sql_cross_join.htm
TLDR;生成2个表之间所有可能的组合(Carthesian积)
(完整)外部加入:http://www.w3schools.com/Sql/sql_join_full.asp
TLDR;返回两个表中的每一行,以及具有相同值的结果(CONDITION中匹配)
完全外部连接组合了左外部连接和右外部连接。结果集从满足条件的两个表中返回行,但在不匹配的地方返回空列。
交叉连接是一种笛卡尔积,它不需要任何条件来连接表。结果集包含的行和列是两个表的乘法。