首页 应用 游戏 资讯 攻略

SQL JOIN 的四种连接方式

时间:2017-03-07 关注公众号 来源:网络

  SQL Join 共有四种连接方式:JOIN,LEFT JOIN,RIGHT JOIN,FULL JOIN。

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

  "Persons" 表:



Id_PLastNameFirstNameAddressCity
1AdamsJohnOxford StreetLondon
2BushGeorgeFifth AvenueNew York
3CarterThomasChangan StreetBeijing

  "Orders" 表:

Id_OOrderNoId_P
1778953
2446783
3224561
4245621
53476465

  内连接(INNER JOIN)实例

  现在,我们希望列出所有人的定购。

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

  SELECT Persons.LastName, Persons.FirstName, Orders.OrderNo

  FROM Persons

  INNER JOIN Orders

  ON Persons.Id_P=Orders.Id_P

  ORDER BY Persons.LastName

  结果集:

LastNameFirstNameOrderNo
AdamsJohn22456
AdamsJohn24562
CarterThomas77895
CarterThomas44678

  INNER JOIN 关键字在表中存在至少一个匹配时返回行。如果 "Persons" 中的行在 "Orders" 中没有匹配,就不会列出这些行。

  注释:INNER JOIN 与 JOIN 是相同的。

  左连接(LEFT JOIN)实例

  现在,我们希望列出所有的人,以及他们的定购 - 如果有的话。

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

  SELECT Persons.LastName, Persons.FirstName, Orders.OrderNo

  FROM Persons

  LEFT JOIN Orders

  ON Persons.Id_P=Orders.Id_P

  ORDER BY Persons.LastName

  结果集:

LastNameFirstNameOrderNo
AdamsJohn22456
AdamsJohn24562
CarterThomas77895
CarterThomas44678
BushGeorge

  LEFT JOIN 关键字会从左表 (Persons) 那里返回所有的行,即使在右表 (Orders) 中没有匹配的行。

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

  右连接(RIGHT JOIN)实例

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

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

  SELECT Persons.LastName, Persons.FirstName, Orders.OrderNo

  FROM Persons

  RIGHT JOIN Orders

  ON Persons.Id_P=Orders.Id_P

  ORDER BY Persons.LastName

  结果集:

LastNameFirstNameOrderNo
AdamsJohn22456
AdamsJohn24562
CarterThomas77895
CarterThomas44678

34764

  RIGHT JOIN 关键字会从右表 (Orders) 那里返回所有的行,即使在左表 (Persons) 中没有匹配的行。

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

  全连接(FULL JOIN)实例

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

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

  SELECT Persons.LastName, Persons.FirstName, Orders.OrderNo

  FROM Persons

  FULL JOIN Orders

  ON Persons.Id_P=Orders.Id_P

  ORDER BY Persons.LastName

  结果集:

LastNameFirstNameOrderNo
AdamsJohn22456
AdamsJohn24562
CarterThomas77895
CarterThomas44678
BushGeorge

34764

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

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

阅读全文
扫码关注“ 多特资源库
更多更全的软件资源下载
文章内容来源于网络,不代表本站立场,若侵犯到您的权益,可联系我们删除。(本站为非盈利性质网站)
玩家热搜

相关攻略

正在加载中
版权
版权说明

文章内容来源于网络,不代表本站立场,若侵犯到您的权益,可联系我们删除。(本站为非盈利性质网站)

电话:13918309914

QQ:1967830372

邮箱:rjfawu@163.com

toast