数据库基础#21:使用JOIN运算符,OUTER JOIN

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.FinancialTransactionPersonnel.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上发布。

评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值