Java面试题:通过实例说明内连接、左外连接和右外连接的区别

在 SQL 中,连接(JOIN)用于在多个表之间组合行。最常用的连接类型是内连接(INNER JOIN)、左外连接(LEFT OUTER JOIN)和右外连接(RIGHT OUTER JOIN)。它们的主要区别在于它们如何处理表之间的匹配和不匹配行。下面是每种连接的详细说明和示例。

表示例

假设有两个表:CustomersOrders

Customers

CustomerIDCustomerName
1Alice
2Bob
3Charlie

Orders

OrderIDCustomerIDOrderDate
10112023-06-01
10212023-06-02
10322023-06-03
10442023-06-04

1. 内连接(INNER JOIN)

内连接返回两个表中匹配的行。如果某一行在其中一个表中没有匹配项,则该行不会出现在结果集中。

SELECT Customers.CustomerID, Customers.CustomerName, Orders.OrderID, Orders.OrderDate
FROM Customers
INNER JOIN Orders ON Customers.CustomerID = Orders.CustomerID;

结果

CustomerIDCustomerNameOrderIDOrderDate
1Alice1012023-06-01
1Alice1022023-06-02
2Bob1032023-06-03

2. 左外连接(LEFT OUTER JOIN)

左外连接返回左表中的所有行,即使右表中没有匹配项。如果右表中没有匹配项,结果集中的相应列将包含 NULL 值。

SELECT Customers.CustomerID, Customers.CustomerName, Orders.OrderID, Orders.OrderDate
FROM Customers
LEFT OUTER JOIN Orders ON Customers.CustomerID = Orders.CustomerID;

结果

CustomerIDCustomerNameOrderIDOrderDate
1Alice1012023-06-01
1Alice1022023-06-02
2Bob1032023-06-03
3CharlieNULLNULL

3. 右外连接(RIGHT OUTER JOIN)

右外连接返回右表中的所有行,即使左表中没有匹配项。如果左表中没有匹配项,结果集中的相应列将包含 NULL 值。

SELECT Customers.CustomerID, Customers.CustomerName, Orders.OrderID, Orders.OrderDate
FROM Customers
RIGHT OUTER JOIN Orders ON Customers.CustomerID = Orders.CustomerID;

结果

CustomerIDCustomerNameOrderIDOrderDate
1Alice1012023-06-01
1Alice1022023-06-02
2Bob1032023-06-03
NULLNULL1042023-06-04

总结

  • 内连接(INNER JOIN):仅返回两个表中都存在匹配项的行。
  • 左外连接(LEFT OUTER JOIN):返回左表中的所有行,如果右表中没有匹配项,则结果集中对应的列包含 NULL 值。
  • 右外连接(RIGHT OUTER JOIN):返回右表中的所有行,如果左表中没有匹配项,则结果集中对应的列包含 NULL 值。

通过这些示例,可以清楚地看出不同类型的连接在处理表之间匹配和不匹配行时的行为差异。

  • 6
    点赞
  • 7
    收藏
    觉得还不错? 一键收藏
  • 打赏
    打赏
  • 0
    评论

“相关推荐”对你有帮助么?

  • 非常没帮助
  • 没帮助
  • 一般
  • 有帮助
  • 非常有帮助
提交
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包

打赏作者

码农超哥同学

赠人玫瑰 手留余香

¥1 ¥2 ¥4 ¥6 ¥10 ¥20
扫码支付:¥1
获取中
扫码支付

您的余额不足,请更换扫码支付或充值

打赏作者

实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

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

余额充值