首页
学习
活动
专区
圈层
工具
发布
社区首页 >问答首页 >连接SQL查询返回到第一个表

连接SQL查询返回到第一个表
EN

Stack Overflow用户
提问于 2015-11-07 10:22:52
回答 1查看 33关注 0票数 1

我有一些MS 2010 link tables链接到第一个表,如下所示:

代码语言:javascript
复制
    Item                LinkTable

[ ID       ]           [ ID        ]
[ ItemName ]-1-------*-[ FromItem  ]
[          ]-1-------*-[ ToItem    ]

图1:FromItemToItem引用'Item.ID'

我想做一个查询,将所有三个表链接在一起,并显示例如折叠字段。

(from)Item.ItemName _ LinkTable.ID _ (to)Item.ItemName

我尝试了以下SQL,但它抱怨第二次出现项,在下面的表达式“Item LEFT JOIN LinkTable”中的FROM子句中有一条消息“无法重复表名”"Item“:

代码语言:javascript
复制
SELECT *
FROM Item LEFT JOIN 
(
Item LEFT JOIN LinkTable ON (LinkTable.ToItem =Item.ID)
)
ON (LinkTable.FromItem = Item.ID);

Q1:为什么我不能链接回像这样的“起始表”而不产生错误消息?

Q2:我应该如何定义选择字段,以便在不混淆它们的情况下同时显示from-ItemName和to-ItemName?(在示例中,我编写了“Select*”以简化)

// Rolf

Edit:______________________________________________________

基于@Andomar (下面)的答复,我得到了以下工作代码。我使用INNER JOIN而不是LEFT JOIN来获得匹配的Items

代码语言:javascript
复制
   SELECT fro.ItemName
   ,      lt.ID
   ,      to.ItemName
   FROM Item fro 
   INNER JOIN (LinkTable lt 
   INNER JOIN Item to ON lt.toItem = to.ID)
   ON fro.ID = lt.fromItem;
EN

回答 1

Stack Overflow用户

回答已采纳

发布于 2015-11-07 10:41:33

您可以化名为表名。例如,将表Item化名为别名i1

代码语言:javascript
复制
FROM   Item i1

现在您可以再次使用相同的表,并使用不同的别名来标识它。将此与多个联接所需的括号访问相结合,您将得到:

代码语言:javascript
复制
SELECT  i1.ItemName
,       i2.ItemName
FROM (Item i1
LEFT JOIN LinkTable lt ON lt.FromItem = i1.ID)
LEFT JOIN item i2 ON i2.ID = lt.ToItem
票数 2
EN
页面原文内容由Stack Overflow提供。腾讯云小微IT领域专用引擎提供翻译支持
原文链接:

https://stackoverflow.com/questions/33581599

复制
相关文章

相似问题

领券
问题归档专栏文章快讯文章归档关键词归档开发者手册归档开发者手册 Section 归档