不同的 SQL JOIN
除了例子中使用的 INNER JOIN(内连接),我们还可以使用其他几种连接。
下面列出了您可以使用的 JOIN 类型,以及它们之间的差异。
-
jion: 如果表中有至少一个匹配,则返回行
注释: inner join与 join是相同的。(内连接)
inner jion 关键字在表中存在至少一个匹配时返回行。如果 “Persons” 中的行在 “Orders” 中没有匹配,就不会列出这些行。
select Persons.LastName, Persons.FirstName, Orders.OrderNo FROM Persons inner join Orders ON Persons.Id_P=Orders.Id_P ORDER BY Persons.LastName
例如:
“Persons” 表
“Orders” 表:
结果集:
-
left join: 即使右表中没有匹配,也从左表返回所有的行**(左连接)**
**注释:**left join 关键字会从左表 (Persons) 那里返回所有的行,即使在右表 (Orders) 中没有匹配的行。
SELECT Persons.LastName, Persons.FirstName, Orders.OrderNo
FROM Persons
LEFT JOIN Orders
ON Persons.Id_P=Orders.Id_P
ORDER BY Persons.LastName
结果集:
-
right join: 即使左表中没有匹配,也从右表返回所有的行**(右连接)**
**注释:**RIGHT JOIN 关键字会从右表 (Orders) 那里返回所有的行,即使在左表 (Persons) 中没有匹配的行。
SELECT Persons.LastName, Persons.FirstName, Orders.OrderNo FROM Persons RIGHT JOIN Orders ON Persons.Id_P=Orders.Id_P ORDER BY Persons.LastName
结果集:
-
full join: 只要其中一个表中存在匹配,就返回行**(全连接)**
**注解:**full join 关键字会从左表 (Persons) 和右表 (Orders) 那里返回所有的行。如果 “Persons” 中的行在表 “Orders” 中没有匹配,或者如果 “Orders” 中的行在表 “Persons” 中没有匹配,这些行同样会列出。
SELECT Persons.LastName, Persons.FirstName, Orders.OrderNo
FROM Persons
FULL JOIN Orders
ON Persons.Id_P=Orders.Id_P
ORDER BY Persons.LastName
结果集: