SQL FULL JOIN 关键字

本章节主要讲解 FULL JOIN 语句的方法。


SQL FULL JOIN 关键字

只要其中某个表存在匹配,FULL JOIN 关键字就会返回行。

FULL JOIN 关键字语法
  1. SELECT column_name(s)
  2. FROM table_name1
  3. FULL JOIN table_name2
  4. ON table_name1.column_name=table_name2.column_name

注释:在某些数据库中,FULL JOIN 称为 FULL OUTER JOIN


原始的表 (用在例子中的):

"Persons" 表:

Id_PLastNameFirstNameAddressCity
1AdamsJohnOxford StreetLondon
2BushGeorgeFifth AvenueNew York
3CarterThomasChangan StreetBeijing

"Orders" 表:

Id_OOrderNoId_P
1778953
2446783
3224561
4245621
53476465

全连接(FULL JOIN)实例

现在,我们希望列出所有的人,以及他们的定单,以及所有的定单,以及定购它们的人。

您可以使用下面的 SELECT 语句:

  1. SELECT Persons.LastName, Persons.FirstName, Orders.OrderNo
  2. FROM Persons
  3. FULL JOIN Orders
  4. ON Persons.Id_P=Orders.Id_P
  5. ORDER BY Persons.LastName

结果集:

LastNameFirstNameOrderNo
AdamsJohn22456
AdamsJohn24562
CarterThomas77895
CarterThomas44678
BushGeorge 
  34764

FULL JOIN 关键字会从左表 (Persons) 和右表 (Orders) 那里返回所有的行。如果 "Persons" 中的行在表 "Orders" 中没有匹配,或者如果 "Orders" 中的行在表 "Persons" 中没有匹配,这些行同样会列出。