首页
学习
活动
专区
工具
TVP
发布
社区首页 >问答首页 >SQL中存在不明确的列名的查询错误

SQL中存在不明确的列名的查询错误
EN

Stack Overflow用户
提问于 2012-10-01 00:35:48
回答 7查看 279.2K关注 0票数 44

在这个查询(InvoiceID)中,我得到了一个不明确的列名错误。我不知道为什么。它们似乎都正确地连接在一起,那么为什么SSMS不知道显示VendorID呢?

查询:

代码语言:javascript
复制
SELECT 
    VendorName, InvoiceID, InvoiceSequence, InvoiceLineItemAmount
FROM Vendors 
JOIN Invoices ON (Vendors.VendorID = Invoices.VendorID)
JOIN InvoiceLineItems ON (Invoices.InvoiceID = InvoiceLineItems.InvoiceID)
WHERE  
    Invoices.InvoiceID IN
        (SELECT InvoiceSequence 
         FROM InvoiceLineItems
         WHERE InvoiceSequence > 1)
ORDER BY 
    VendorName, InvoiceID, InvoiceSequence, InvoiceLineItemAmount
EN

回答 7

Stack Overflow用户

发布于 2012-10-01 00:38:37

您在Invoices表和InvoiceLineItems表中都有一个列InvoiceID。查询执行引擎没有办法知道您想要返回哪一个。

添加表别名将有所帮助:

代码语言:javascript
复制
SELECT V.VendorName, I.InvoiceID, IL.InvoiceSequence, IL.InvoiceLineItemAmount
FROM Vendors V
JOIN Invoices I ON (...)
JOIN InvoiceLineItems IL ON (...)
WHERE ...
ORDER BY V.VendorName, I.InvoiceID, IL.InvoiceSequence, IL.InvoiceLineItemAmount
票数 9
EN

Stack Overflow用户

发布于 2012-10-01 00:40:50

因为您连接的是两个都包含InvoiceID的表Invoices和InvoiceLineItems。更改为Invoices.InvoiceID以使其正确。

票数 6
EN

Stack Overflow用户

发布于 2012-10-01 00:39:05

这两个表很可能都有一个同名的列。为每个表取别名,并使用表别名调用每个列。

票数 4
EN
页面原文内容由Stack Overflow提供。腾讯云小微IT领域专用引擎提供翻译支持
原文链接:

https://stackoverflow.com/questions/12662954

复制
相关文章

相似问题

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