LEFT JOIN和LEFT OUTER JOIN之间的区别是什么?


当前回答

左连接和左外部连接是相同的。前者是后者的简写。右联接和右外部联接关系也是如此。这次示威将说明平等。通过SQLFiddle提供了每个查询的工作示例。该工具将允许手动操作查询。

鉴于

左连接和左外部连接

后果


右连接和右外部连接

后果

其他回答

我是一名PostgreSQL DBA,据我所知,外部连接和非外部连接之间的区别是一个在互联网上有大量讨论的话题。直到今天,我从未看到这两者之间的区别;所以我更进一步,我试图找出它们之间的区别。最后,我阅读了关于它的全部文档,我找到了答案,

因此,如果您查看文档(至少在PostgreSQL中),您可以找到以下短语:

INNER和OUTER在所有形式中都是可选的。INNER是默认值;LEFT、RIGHT和FULL表示外部连接

换句话说,

左联接和左外部联接相同

右联接和右外部联接相同

我希望它能为那些仍在努力寻找答案的人做出贡献。

左连接和左外部连接之间的区别是什么?

没有什么LEFT JOIN和LEFT OUTER JOIN是等效的。

我发现按以下顺序更容易想到联接:

CROSS JOIN-两个表的笛卡尔乘积。所有连接从此处开始INNER JOIN-添加了过滤器的CROSS JOIN。OUTER JOIN-缺少元素的INNER JOIN(来自LEFT或RIGHT表)随后添加。

在我找到这个(相对)简单的模型之前,JOIN总是有点像一门黑色艺术。现在它们很有意义。

希望这能帮助你,而不是让你困惑。

就在这个问题的上下文中,我还想发布2个“APPLY”运算符:

连接:

内部联接=联接外部连接左外部联接=左联接右外部联接=右联接完全外部连接=完全连接交叉连接

SelfJOIN:这不是一种单独的联接类型。这基本上是使用上述连接之一将表连接到自身。但我觉得在JOIN讨论中值得一提,因为您将从SQL Developer社区的许多人那里听到这个术语。

应用:

CROSS APPLY——类似于INNER JOIN(但增加了一个优点,即能够为Left表的每一行在Right表中计算一些值,并且只返回匹配的行)OUTER APPLY——类似于LEFT OUTER JOIN(但它增加了一个优点,即能够为LEFT表的每一行计算Right表中的某些内容,并且无论Right表中是否匹配,都会返回LEFT表中的所有行)

https://www.mssqltips.com/sqlservertip/1958/sql-server-cross-apply-and-outer-apply/

https://sqlhints.com/2016/10/23/outer-apply-in-sql-server/

实际示例,何时在SQL中使用OUTER/CROSS APPLY

我发现APPLY运算符非常有用,因为它们提供了比在子查询中进行相同计算更好的性能。它们还取代了旧版本SQL Server中的许多分析函数。这就是为什么我相信在熟悉JOIN之后,一个SQL开发人员接下来应该尝试学习APPLY运算符。

回答您的问题

在Sql Server中,连接语法OUTER是可选的

msdn文章中提到:https://msdn.microsoft.com/en-us/library/ms177634(v=sql.130).aspx

所以下面的列表显示了具有和不具有OUTER的连接等效语法

LEFT OUTER JOIN => LEFT JOIN
RIGHT OUTER JOIN => RIGHT JOIN
FULL OUTER JOIN => FULL JOIN

其他等效语法

INNER JOIN => JOIN
CROSS JOIN => ,

强烈推荐Dotnet Mob Artice:加入Sql Server