OUTER JOIN返回一组完整的数据,然后返回另一组的匹配值。语法与INNER JOIN基本相同,但您必须包括是否正在处理RIGHT或LEFT JOIN。OUTER字,就像INNER关键字一样,不是必需的。
外联
想象一下你有一份人员名单的情况。其中一些人有金融交易,但有些人没有。如果您想要一个列出系统中所有人的查询,包括那些包含财务事务的人,则查询可能如下所示:
SELECT p .LastName,
ft .TransactionAmount,
ft .TransactionDate,
ft .TransactionTime
来自人事.Person AS p
LEFT JOIN财经.FinancialTransaction AS英尺
ON p .PersonID = ft .PersonID ;
除了添加LEFT关键字之外,此查询可以很容易地使用INNER JOIN操作,直到您看到此处显示的结果:
虽然可能看起来更多数据已添加到Personnel.Person表中,但它没有。正在发生的是如何描述OUTER JOIN。OUTER JOIN返回LEFT或RIGHT表中的所有行,这些行由该表中的六个名称表示。然后OUTER JOIN会添加第二个结果集中的所有匹配行,这就是为什么你看到值'Adolphus'三次,因为它匹配Finance.FinancialTransaction表中的三个不同的行。如果您反转查询:
SELECT p .LastName,
ft .TransactionAmount,
ft .TransactionDate,
ft .TransactionTime
来自人事.Person AS p
RIGHT JOIN财经.FinancialTransaction AS英尺
ON p .PersonID = ft .PersonID ;
在这种情况下,您将从RIGHT表中获取所有行 Finance.FinanacialTransaction
,并匹配Personnel.Person表中的行以显示结果:
图5:15:相同OUTER JOIN的结果反转为RIGHT JOIN
这可能看起来像一个内部联接,但这只是因为提供的数据看起来像这样。RIGHT表中的所有行在 Finance.FinancialTransaction
Personnel.Person表中都有对应的行,并且没有重复值或缺失值会导致您已经看到的乘法因子。
您可以向FROM子句添加更多表,并为它们定义OUTER JOIN条件。您还可以在不同的表集之间组合OUTER JOIN和INNER JOIN。您只需要小心,在将各种类型的JOINS与多个表放在一起时,您将完全理解将返回哪些数据。
最后,在使用OUTER JOIN时需要谨慎过滤。如果在查询的WHERE子句中放置OUTER JOIN的过滤器,它基本上会破坏OUTER JOIN,将其转换为INNER JOIN。因此,虽然过滤通常应在WHERE或HAVING子句中完成,但在OUTER JOIN的情况下,请务必将过滤器置于ON条件中。
结论
无论您使用LEFT还是RIGHT连接,基本行为都不会改变,但逻辑确实如此,因此在编写查询时要做出相应的计划。基础系列的下一篇文章将在CROSS JOIN上发布。