MySQL - FULL JOIN

SQL FULL JOIN 关键字

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

FULL JOIN 关键字语法

SELECT column_name(s)
FROM table_name
FULL JOIN table_name
ON table_name.column_name=table_name.column_name and table_name.column_name=table_name.column_name and...
FULL JOIN table_name
ON table_name.column_name=table_name.column_name and table_name.column_name=table_name.column_name and...
...
WHERE table_name.column_name = ? and table_name.column_name = ? and....
ORDER BY table_name.column_name, table_name.column_name
 

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

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

"Persons" 表:ci

Id_P  LastName  FirstName  Address City
1 Adams John Oxford Street London
2 Bush George Fifth Avenue New York 
3 Carter Thomas Changan Street  Beijing

"Orders" 表:it

Id_O  OrderNo  Id_P 
1 77895 3
2 44678 3
3 22456 1
4 24562 1
5 34764 65

全链接(FULL JOIN)实例

如今,咱们但愿列出全部的人,以及他们的定单,以及全部的定单,以及定购它们的人。table

您能够使用下面的 SELECT 语句:ast

SELECT Persons.LastName, Persons.FirstName, Orders.OrderNo
FROM Persons
FULL JOIN Orders
ON Persons.Id_P=Orders.Id_P
ORDER BY Persons.LastName

结果集:语法

LastName  FirstName  OrderNo 
Adams John 22456
Adams John 24562
Carter Thomas 77895
Carter Thomas 44678
Bush George
 
 
 
34764

FULL JOIN 关键字会从左表 (Persons) 和右表 (Orders) 那里返回全部的行。若是 "Persons" 中的行在表 "Orders" 中没有匹配,或者若是 "Orders" 中的行在表 "Persons" 中没有匹配,这些行一样会列出。数据

相关文章
相关标签/搜索