轻松上手,快乐学习!

SQL FULL OUTER JOIN 关键字


SQL FULL OUTER JOIN关键字

当左(table1)或右(table2)表记录匹配时,FULL OUTER JOIN关键字返回所有记录。

注意: FULL OUTER JOIN可能会返回非常大的结果集!

提示: FULL OUTER JOIN和FULL JOIN是相同的。

FULL OUTER JOIN语法

SELECT column_name(s)
FROM table1
FULL OUTER JOIN table2
 ON table1.column_name = table2.column_name
WHERE condition;


演示数据库

在本教程中,我们将使用着名的Northwind示例数据库。

以下是“Customers”表中的一个选择:

CustomerID CustomerName ContactName Address City PostalCode Country
1 Alfreds Futterkiste Maria Anders Obere Str. 57 Berlin 12209 Germany
2 Ana Trujillo Emparedados y helados Ana Trujillo Avda. de la Constituciуn 2222 Mйxico D.F. 05021 Mexico
3 Antonio Moreno Taquerнa Antonio Moreno Mataderos 2312 Mйxico D.F. 05023 Mexico

并从“订单”表中选择:

OrderID CustomerID EmployeeID OrderDate ShipperID
10308 2 7 1996-09-18 3
10309 37 3 1996-09-19 1
10310 77 8 1996-09-20 2

SQL FULL OUTER JOIN 实例

以下SQL语句选择所有客户和所有订单:

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

结果集如下所示:

CustomerName OrderID
Alfreds Futterkiste
Ana Trujillo Emparedados y helados 10308
Antonio Moreno Taquerнa 10365
10382
10351

注意: FULL OUTER JOIN关键字返回两个表中的所有匹配记录,无论其他表是否匹配。因此,如果“客户”中的行中没有“订单”中的匹配项,或者“订单”中的行中没有“客户”中的匹配项,则也会列出这些行。