左连接和右连接:因为我可以反转操作数,实际区别是啥?
Posted
技术标签:
【中文标题】左连接和右连接:因为我可以反转操作数,实际区别是啥?【英文标题】:left and right joins: what is the actual difference since I can invert the operands?左连接和右连接:因为我可以反转操作数,实际区别是什么? 【发布时间】:2012-03-24 16:44:41 【问题描述】:我正在学习 SQL,我根本没有做任何测试,所以我很抱歉我的愚蠢问题。 显然(在我的猜测中,LOL)LEFT 和 RIGHT 连接可以等效地反转表(操作数)。是这样吗?
如果是,那为什么我更喜欢写这个:
SELECT * FROM aaa LEFT OUTER JOIN bbb ON aaa.x = bbb.x
而不是这个:
SELECT * FROM bbb RIGHT OUTER JOIN aaa ON aaa.x = bbb.x
【问题讨论】:
ON
子句中的顺序无关紧要——重要的是外连接的内容和方式(左、右、全)。就个人而言,我看不到RIGHT
的用途,我总是使用LEFT
...
我知道 a=b 和 b=a 没有区别,我说的是连接操作数
只要表和的操作数颠倒,它们是等价的。无论 OUTER JOIN'd 是什么,都变成可选的(意思是,如果没有定义关系的数据,则该引用中的任何列都可以是 NULL
)。
与NATURAL JOIN
的原因相同——ANSI 并不完美,它有助于指示方向。另外,不能有 LEFT 没有 RIGHT。这就像说你相信撒旦,但不相信上帝......
是的,但是为什么需要方向,因为我可以反转表名?例如 >= 和 = b === b
【参考方案1】:
我发现最好的方法是看看下面的图片清除你的疑问
原始答案:How do I decide when to use right joins/left joins or inner joins Or how to determine which table is on which side?
【讨论】:
是的,但这不能回答我的问题:选择图像的第一个左上角示例 (SELECT * FROM aaa LEFT JOIN bbb ON aaa.x=bbb.x) 相当于 (SELECT * FROM bbb RIGHT JOIN aaa ON aaa.x=bbb.x) 与否? 所以...再次,LEFT 和 RIGHT 之间的实际区别是什么,如果有的话,因为我可以反转表名? @toPeerOrNotToPeer - 这取决于您的兴趣,但您编写它的方式并没有任何区别 而在更复杂的查询中,左右可以使结果有所不同,或者在任何情况下都可以为程序员提供方便? @toPeerOrNotToPeer - 正如我所说,这取决于您的兴趣..您必须选择要使用的。【参考方案2】:在许多情况下,您必须连接超过 2 个表 - 例如需要来自超过 2 个表的数据的存储过程、视图或查询 - 。在这些情况下,您需要为查询选择一个起点 - 在本例中是一个表。
在其中一个表“aaa”将适合开始查询,在其他“bbb”会更好。
这就是存在LEFT
和RIGHT
连接的原因。
【讨论】:
以上是关于左连接和右连接:因为我可以反转操作数,实际区别是啥?的主要内容,如果未能解决你的问题,请参考以下文章