本文主要是介绍Java面试题:通过实例说明内连接、左外连接和右外连接的区别,希望对大家解决编程问题提供一定的参考价值,需要的开发者们随着小编来一起学习吧!
在 SQL 中,连接(JOIN)用于在多个表之间组合行。最常用的连接类型是内连接(INNER JOIN)、左外连接(LEFT OUTER JOIN)和右外连接(RIGHT OUTER JOIN)。它们的主要区别在于它们如何处理表之间的匹配和不匹配行。下面是每种连接的详细说明和示例。
表示例
假设有两个表:Customers
和 Orders
。
Customers
CustomerID | CustomerName |
---|---|
1 | Alice |
2 | Bob |
3 | Charlie |
Orders
OrderID | CustomerID | OrderDate |
---|---|---|
101 | 1 | 2023-06-01 |
102 | 1 | 2023-06-02 |
103 | 2 | 2023-06-03 |
104 | 4 | 2023-06-04 |
1. 内连接(INNER JOIN)
内连接返回两个表中匹配的行。如果某一行在其中一个表中没有匹配项,则该行不会出现在结果集中。
SELECT Customers.CustomerID, Customers.CustomerName, Orders.OrderID, Orders.OrderDate
FROM Customers
INNER JOIN Orders ON Customers.CustomerID = Orders.CustomerID;
结果
CustomerID | CustomerName | OrderID | OrderDate |
---|---|---|---|
1 | Alice | 101 | 2023-06-01 |
1 | Alice | 102 | 2023-06-02 |
2 | Bob | 103 | 2023-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;
结果
CustomerID | CustomerName | OrderID | OrderDate |
---|---|---|---|
1 | Alice | 101 | 2023-06-01 |
1 | Alice | 102 | 2023-06-02 |
2 | Bob | 103 | 2023-06-03 |
3 | Charlie | NULL | NULL |
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;
结果
CustomerID | CustomerName | OrderID | OrderDate |
---|---|---|---|
1 | Alice | 101 | 2023-06-01 |
1 | Alice | 102 | 2023-06-02 |
2 | Bob | 103 | 2023-06-03 |
NULL | NULL | 104 | 2023-06-04 |
总结
- 内连接(INNER JOIN):仅返回两个表中都存在匹配项的行。
- 左外连接(LEFT OUTER JOIN):返回左表中的所有行,如果右表中没有匹配项,则结果集中对应的列包含 NULL 值。
- 右外连接(RIGHT OUTER JOIN):返回右表中的所有行,如果左表中没有匹配项,则结果集中对应的列包含 NULL 值。
通过这些示例,可以清楚地看出不同类型的连接在处理表之间匹配和不匹配行时的行为差异。
这篇关于Java面试题:通过实例说明内连接、左外连接和右外连接的区别的文章就介绍到这儿,希望我们推荐的文章对编程师们有所帮助!