我在SO上看到过类似的错误,但我没有找到解决我的问题的方法。 我有一个SQL查询像:

SELECT DISTINCT
        a.maxa ,
        b.mahuyen ,
        a.tenxa ,
        b.tenhuyen ,
        ISNULL(dkcd.tong, 0) AS tongdkcd
FROM    phuongxa a ,
        quanhuyen b
        LEFT OUTER JOIN ( SELECT    maxa ,
                                    COUNT(*) AS tong
                          FROM      khaosat
                          WHERE     CONVERT(DATETIME, ngaylap, 103) BETWEEN 'Sep 1 2011'
                                                              AND
                                                              'Sep 5 2011'
                          GROUP BY  maxa
                        ) AS dkcd ON dkcd.maxa = a.maxa
WHERE   a.maxa <> '99'
        AND LEFT(a.maxa, 2) = b.mahuyen
ORDER BY maxa;

当我执行这个查询时,错误结果是: 无法绑定多部分标识符“a.maxa”。为什么? P/s:如果我把查询分成2个单独的查询,它运行正常。

SELECT DISTINCT
        a.maxa ,
        b.mahuyen ,
        a.tenxa ,
        b.tenhuyen
FROM    phuongxa a ,
        quanhuyen b
WHERE   a.maxa <> '99'
        AND LEFT(a.maxa, 2) = b.mahuyen
ORDER BY maxa;

and

SELECT  maxa ,
        COUNT(*) AS tong
FROM    khaosat
WHERE   CONVERT(DATETIME, ngaylap, 103) BETWEEN 'Sep 1 2011'
                                        AND     'Sep 5 2011'
GROUP BY maxa;

当前回答

对我来说,我使用了错误的别名拼写,它在正确的拼写后工作

其他回答

你是不是忘了找几张桌子?如果不是,那么你可能需要使用一些别名。

如果此错误发生在UPDATE中,请再次检查表上导致错误的列/字段的JOIN。

在我的例子中,这是由于缺乏JOIN本身,它由于未知字段而产生了相同的错误(正如Andriy指出的那样)。

对我来说,我使用了错误的别名拼写,它在正确的拼写后工作

当以错误的方式在查询中使用模式(dbo)时,有时会发生此错误。

例如,如果你写:

select dbo.prd.name
from dbo.product prd

您将得到错误。

在这种情况下,将其更改为:

select prd.name
from dbo.product prd

我在SQL SERVER中遇到了同样的错误消息,因为我有多个连接,改变连接的顺序为我解决了这个问题。