LEFT JOIN和LEFT OUTER 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运算符。
其他回答
JOIN主要有三种类型
内部:获取两个表中存在的数据仅JOIN表示INNER JOIN外部:有三种类型LEFT OUTER--仅获取左表匹配条件中的数据RIGHT OUTER--仅获取右表匹配条件下的数据FULL OUTER—获取任何或两个表中的数据(LEFT或RIGHT或FULL)OUTER JOIN可以不写“OUTER”交叉连接:将所有内容连接到所有内容
要回答您的问题,LEFT JOIN之间没有区别和LEFT OUTER JOIN,它们和上面说的完全一样。。。
在顶层,主要有3种连接类型:
内部外部十字
INNER JOIN-如果两个表中都存在,则获取数据。OUTER JOIN有三种类型:LEFT OUTER JOIN-获取左表中存在的数据。RIGHT OUTER JOIN-如果右表中存在,则获取数据。FULL OUTER JOIN-如果两个表中的任何一个表中存在,则获取数据。顾名思义,CROSS JOIN是将所有事物连接到所有事物的[n X m]。类似于我们简单列出要连接的表(在SELECT语句的FROM子句中)的场景,使用逗号分隔它们。
注意事项:
如果您只提到JOIN,那么默认情况下它是INNER JOIN。OUTER联接必须是LEFT|RIGHT|FULL,不能简单地说OUTER联接。您可以删除OUTER关键字,只需说LEFT JOIN或RIGHT JOIN或FULL JOIN。
对于那些希望以更好的方式可视化这些内容的人,请访问以下链接:SQL联接的可视化解释
只有3个连接:
A) 交叉连接=笛卡尔(例如:表A、表B)B) 内部联接=联接(例如:表A联接/内部联接表B)C) 外部连接:有三种类型的外部连接左外部联接=左联接右外部联接=右联接完全外部联接=完全联接
就在这个问题的上下文中,我还想发布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运算符。
左连接和左外部连接是相同的。前者是后者的简写。右联接和右外部联接关系也是如此。这次示威将说明平等。通过SQLFiddle提供了每个查询的工作示例。该工具将允许手动操作查询。
鉴于
左连接和左外部连接
后果
右连接和右外部连接
后果
推荐文章
- 如何在SQL中选择表的最后一条记录?
- 修改列,添加默认约束
- 在存储过程中使用“SET XACT_ABORT ON”有什么好处?
- 如何检查SQL Server文本列是否为空?
- 如何创建一个SQL Server函数“连接”多行从一个子查询到一个单独的分隔字段?
- 在SQL中更新多个列
- 如何删除表中特定列的第一个字符?
- 等价的限制和偏移SQL Server?
- 如何从SQL Server中的字符串中剥离所有非字母字符?
- 为什么我不能在DELETE语句中使用别名?
- 多语句表值函数vs内联表值函数
- NOLOCK提示在SELECT语句中的作用
- SQL OVER()子句-它什么时候有用,为什么有用?
- 检查SQL Server登录是否已经存在
- 我如何使用ROW_NUMBER()?