📜  Oracle OUTER JOIN(1)

📅  最后修改于: 2023-12-03 15:18:08.587000             🧑  作者: Mango

Oracle OUTER JOIN

在 Oracle 数据库中,OUTER JOIN 是一个关键字,用于表之间进行连接操作。OUTER JOIN 包括 LEFT OUTER JOIN、RIGHT OUTER JOIN 和 FULL OUTER JOIN,它们分别连接两个表,并返回一个联合的结果集。其中,LEFT OUTER JOIN 和 RIGHT OUTER JOIN 只连接两个表中的一部分记录,并返回连接后的记录集(包括未匹配的记录),而 FULL OUTER JOIN 则返回两个表全部的记录集。

语法
SELECT column1, column2, ...
FROM table1
LEFT OUTER JOIN table2
ON condition

在语法中,SELECT 用于从表中选择需要查询的列,FROM 用于指定查询的表,LEFT OUTER JOIN 用于指定需要连接的表,ON 用于指定连接条件。如果条件为空,则使用 CROSS JOIN 进行连接。

实例
LEFT OUTER JOIN

以下实例演示了如何使用 LEFT OUTER JOIN 将两个表进行连接,并返回表中所有的记录:

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

在以上查询中,Customers 表和 Orders 表通过 CustomerID 列连接。LEFT OUTER JOIN 返回 Customers 表的所有记录,以及 Orders 表中与其匹配的记录。如果 Customers 表的记录在 Orders 表中没有匹配,则相应的 OrderID 列的值为 NULL。

RIGHT OUTER JOIN

以下实例演示了如何使用 RIGHT OUTER JOIN 将两个表进行连接,并返回表中所有的记录:

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

在以上查询中,Customers 表和 Orders 表通过 CustomerID 列连接。RIGHT OUTER JOIN 返回 Orders 表的所有记录,以及 Customers 表中与其匹配的记录。如果 Orders 表的记录在 Customers 表中没有匹配,则相应的 CustomerName 列的值为 NULL。

FULL OUTER JOIN

以下实例演示了如何使用 FULL OUTER JOIN 将两个表进行连接,并返回表中所有的记录:

SELECT Customers.CustomerName, Orders.OrderID
FROM Customers
FULL OUTER JOIN Orders
ON Customers.CustomerID=Orders.CustomerID
ORDER BY Customers.CustomerName;

在以上查询中,Customers 表和 Orders 表通过 CustomerID 列连接。FULL OUTER JOIN 返回所有 Customers 表和 Orders 表的记录,并把所有未匹配的记录中的列值都设为 NULL。

总结

在 Oracle 数据库中,使用 OUTER JOIN 关键字可连接多个表,并返回表中所有记录。LEFT OUTER JOIN 返回第一个表中的所有记录和第二个表中匹配的记录,RIGHT OUTER JOIN 返回第一个表中的匹配记录和第二个表中的所有记录,而 FULL OUTER JOIN 则返回两个表中匹配和不匹配的所有记录。