gpt4 book ai didi

c# - 获取 "The multi-part identifier &RAUM.ID; could not be bound"SQL 错误

转载 作者:行者123 更新时间:2023-12-02 22:38:57 38 4
gpt4 key购买 nike

我有以下 SQL 查询:

SELECT 
r.BEZEICHNUNG AS BEZEICHNUNG, r.ID AS ID, ra.BEZEICHNUNG AS raumBEZEICHNUNG,
ra.ID AS raumID
FROM RAUM r, RAUMATTRIBUTE ra
INNER JOIN RAZUORDNUNG ON RAZUORDNUNG.RAUM_ID = RAUM.ID
INNER JOIN RAUMATTRIBUTE ON RAZUORDNUNG.RAUMATTRIBUTE_ID = RAUMATTRIBUTE.ID
WHERE
RAUMKLASSE_ID = ISNULL(@Raumklasse_ID, RAUMKLASSE_ID)
AND STADT_ID = ISNULL(@Stadt_ID, STADT_ID)
AND GEBAEUDE_ID = ISNULL(@Gebaeude_ID, GEBAEUDE_ID)
AND REGION_ID = ISNULL(@Region_ID, REGION_ID)

如果我使用那个查询,我会得到一个错误:

The multi-part identifier &RAUM.ID; could not be bound.`

为什么会这样,我该如何解决?

最佳答案

由于您已经为表 RAUM 定义了表别名(在 FROM RAUM r 中),因此您需要使用该表别名 - 所以使用 r.ID 而不是 RAUM.ID

SELECT 
r.BEZEICHNUNG AS BEZEICHNUNG, r.ID AS ID, ra.BEZEICHNUNG AS raumBEZEICHNUNG,
ra.ID AS raumID
FROM RAUM r, RAUMATTRIBUTE ra <== you're defining "r" to be alias for "RAUM"
INNER JOIN RAZUORDNUNG ON RAZUORDNUNG.RAUM_ID = RAUM.ID <== you need to use "r.ID"
......

此外,我强烈建议您停止使用仅以逗号分隔的表的“旧式”JOIN - 请改用正确的 ANSI INNER JOIN 语法:

SELECT 
r.BEZEICHNUNG AS BEZEICHNUNG, r.ID AS ID,
ra.BEZEICHNUNG AS raumBEZEICHNUNG, ra.ID AS raumID
FROM RAUM r
INNER JOIN RAZUORDNUNG rz ON rz.RAUM_ID = r.ID
INNER JOIN RAUMATTRIBUTE ra ON rz.RAUMATTRIBUTE_ID = ra.ID
WHERE
RAUMKLASSE_ID = ISNULL(@Raumklasse_ID, RAUMKLASSE_ID)
AND STADT_ID = ISNULL(@Stadt_ID, STADT_ID)
AND GEBAEUDE_ID = ISNULL(@Gebaeude_ID, GEBAEUDE_ID)
AND REGION_ID = ISNULL(@Region_ID, REGION_ID)

您还没有在 RAUM rRAUMATTRIBUTE ra 之间定义任何 JOIN 条件 - 所以您基本上得到了 CROSS JOIN(笛卡尔积)。那是你要的吗?如果不是:在 INNER JOIN 语句中定义适当的 JOIN 条件。

关于c# - 获取 "The multi-part identifier &RAUM.ID; could not be bound"SQL 错误,我们在Stack Overflow上找到一个类似的问题: https://stackoverflow.com/questions/11028887/

38 4 0
Copyright 2021 - 2024 cfsdn All Rights Reserved 蜀ICP备2022000587号
广告合作:1813099741@qq.com 6ren.com