左右连接:因为我可以反转操作数,实际差异是什么?

时间:2012-03-07 06:14:25

标签: sql join

我正在学习SQL,我根本没有考试,所以我很抱歉我的愚蠢问题。 显然(在我的猜测LOL中)LEFT和RIGHT join可以等效反转表(操作数)。这是对的吗?

如果是,那么为什么我更愿意这样写:

SELECT * FROM aaa LEFT OUTER JOIN bbb ON aaa.x = bbb.x

而不是:

SELECT * FROM bbb RIGHT OUTER JOIN aaa ON aaa.x = bbb.x

2 个答案:

答案 0 :(得分:8)

我发现的最佳方式是看下面的图像清楚你怀疑

Orignal Ans at:How do I decide when to use right joins/left joins or inner joins Or how to determine which table is on which side?

alt text

答案 1 :(得分:3)

在许多情况下,您必须加入2个以上的表 - 例如存储过程,视图或查询,您需要来自2个以上表的数据 - 。在这些情况下,您需要为查询选择一个起点 - 在本例中为表格。

在其中一个,表“aaa”将适合用于启动查询,在其他“bbb”中会更好。

这就是为什么LEFTRIGHT加入存在的原因。