如何给同一表的两个外键写SQL查询

日期: 2008-10-26 作者:Rudy Limeback翻译:April 来源:TechTarget中国 英文

问:当以其中的一个表有两个外键指向另一个表的主键时,我们怎样从两个表中检索数据?例如,表A有两个列,Parent_ID和Child_ID。表B有两个列,ID和名字。我们怎样检索数据并让这些数据按照Parent_ID、Parent_Name、Child_ID和Child_Name显示。   答:只要将这个表连结两次。

完成之后,你就必须使用表别名:  SELECT a.Parent_ID           , bp.Name AS Parent_Name &……

我们一直都在努力坚持原创.......请不要一声不吭,就悄悄拿走。

我原创,你原创,我们的内容世界才会更加精彩!

【所有原创内容版权均属TechTarget,欢迎大家转发分享。但未经授权,严禁任何媒体(平面媒体、网络媒体、自媒体等)以及微信公众号复制、转载、摘编或以其他方式进行使用。】

微信公众号

TechTarget微信公众号二维码

TechTarget

官方微博

TechTarget中国官方微博二维码

TechTarget中国

电子邮件地址不会被公开。 必填项已用*标注

敬请读者发表评论,本站保留删除与本文无关和不雅评论的权力。

问:当以其中的一个表有两个外键指向另一个表的主键时,我们怎样从两个表中检索数据?例如,表A有两个列,Parent_ID和Child_ID。表B有两个列,ID和名字。我们怎样检索数据并让这些数据按照Parent_ID、Parent_Name、Child_ID和Child_Name显示。

  答:只要将这个表连结两次。完成之后,你就必须使用表别名: 


SELECT a.Parent_ID 
         , bp.Name AS Parent_Name
         , a.Child_ID
         , bc.Name AS Child_Name
      FROM TableA AS a
    INNER
      JOIN TableB AS bp
        ON bp.ID = a.Parent_ID
    INNER
      JOIN TableB AS bc
        ON bc.ID = a.Child_ID


  注意在这一查询中TableB会出现两次。这就是说我们在它每次出现时都必须使用别名,而且要用SELECT语句、用合适的别名限定这些列。由于TableB两个实例中的列有相同的名称,即这一名称是共有的但不是必需的——所以我们要用SELECT语句对表别名复值。

翻译

April
April

相关推荐