我已创建以下SP以生成更新语句,并使用该表 Col.TMap.T_Mp和表中的数据如下所示:
ID M_Type ID_F SF1 SF2
1 Acc ACC_ID AC_ID NULL
1 STA STA_ID ST_ID NULL
1 CHa Cha_ID CH_ID NULL
CREATE PROCEDURE dbo.dtmap(
@ID INT
)
AS
BEGIN
DECLARE @SQL NVARCHAR(MAX)
DECLARE @SchemaName SYSNAME
DECLARE @TableName SYSNAME
DECLARE @DatabaseName SYSNAME
DECLARE @M_Type SYSNAME
DECLARE @SF1 VARCHAR(50)
DECLARE @SF2 VARCHAR(50)
DECLARE @ID_F VARCHAR(50)
DECLARE @BR CHAR(2)
SET @BR = CHAR(13) + CHAR(10)
DECLARE tickmapcur CURSOR FOR SELECT M_Type,ID_F,SF1,SF2
FROM Col.TMap.T_Mp
WHERE [_ID] = @ID
SELECT @SchemaName = Source_Schema ,
@TableName = Source_Table ,
@DatabaseName = Source_Database
FROM Manserv.dbo.S_Ds
WHERE ID = @ID
OPEN tickmapcur
FETCH NEXT FROM tickmapcur INTO @M_Type,@ID_F,@SF1,@SF2
while @@fetch_status = 0
BEGIN
SET @SQL = 'SELECT SO1,
SO2,
ID
INTO ' + @M_Type + '_mtemp' + @BR + 'FROM ' + @M_Type + @BR
+ 'WHERE [ID] = ' + CAST(@ID AS NVARCHAR(10)) + @BR+ @BR
SET @SQL = @SQL + 'UPDATE mt ' + @BR + 'SET ' + @ID_F+ ' = ac.' + @ID_F
+ @BR + 'FROM ' + @DatabaseName + '.' + @SchemaName + '.' + @TableName + ' t' + @BR
+ 'LEFT OUTER JOIN '+ @M_Type + '_mtemp'
+' mtemp ON mtemp.ID = ' + CAST(@ID AS NVARCHAR(10)) + @BR
+ 'INNER JOIN ' + @M_Type + ' ac ON t.' + @SF1
+ COALESCE(mtemp.SO1, '') + ' SV1'
+ CASE WHEN @SF2 is NULL THEN '' ELSE COALESCE(@SF2, '')
+ COALESCE(mtemp.SO2, '') + ' SV2' END
+ 'AND ac.[ID] = ' + CAST(@ID AS NVARCHAR(10))
+ @BR + 'INNER JOIN ' + @DatabaseName + '.' + @SchemaName + '.'
+ @TableName + '_Dmtemp mt' + @BR
+ 'ON mt.[SRID] = t.[RID] ' + @BR
+@BR
FETCH NEXT FROM tickmapcur INTO @M_Type,@ID_F,@SF1,@SF2
PRINT ( @SQL )
END
CLOSE tickmapcur
DEALLOCATE tickmapcur
END
我收到以下消息:
Msg 4104, Level 16, State 1, Procedure dtmap, Line 57
The multi-part identifier "mtemp.SO1" could not be bound.
Msg 4104, Level 16, State 1, Procedure dtmap, Line 57
The multi-part identifier "mtemp.SO1" could not be bound.
输出应该是这样的:
SELECT SO1,
SO2,
ID
INTO ACC_Mtemp
FROM ACC
WHERE [ID] = @ID
UPDATE mt
SET ACC_ID = ac.ACC_ID
FROM Ms.AT.AT_CRAW t
LEFT OUTER JOIN ACC_Mtemp mtemp ON
mtemp.ID = @ID
INNER JOIN Acc ac ON t.AC_ID=SV1
AND ac.ID = 1
INNER JOIN Ms.AT.AT_CRAW_Dmtemp mt mt
ON mt.[SRID] = t.[RID]
SELECT SO1,
SO2,
ID
INTO STA_Mtemp
FROM STA
WHERE [ID] = @ID
UPDATE mt
SET STA_ID = ac.STA_ID
FROM Ms.AT.AT_CRAW t
LEFT OUTER JOIN STA_Mtemp mtemp ON
mtemp.ID = @ID
INNER JOIN STA ac ON t.ST_ID=SV1
AND ac.ID = 1
INNER JOIN Ms.AT.AT_CRAW_Dmtemp mt mt
ON mt.[SRID] = t.[RID]
SELECT SO1,
SO2,
ID
INTO CHa_Mtemp
FROM CHa
WHERE [ID] = @ID
UPDATE mt
SET CHa_ID = ac.CHa_ID
FROM Ms.AT.AT_CRAW t
LEFT OUTER JOIN CHa_Mtemp mtemp ON
mtemp.ID = @ID
INNER JOIN CHa ac ON t.CH_ID=SV1
AND ac.ID = 1
INNER JOIN Ms.AT.AT_CRAW_Dmtemp mt mt
ON mt.[SRID] = t.[RID]
答案 0 :(得分:1)
创建字符串时,不能使用mtemp
别名。我想你想在查询中使用它:
+ ' COALESCE(mtemp.SO1, '''') SV1'
mtemp.SO2
两行相同。
答案 1 :(得分:1)
您正在错误地构建查询。所有SQL部分都需要引号。它们之外唯一的东西应该是你传入的变量。
答案 2 :(得分:0)
看起来您在COALESCE(mtemp.SO1, '')
部分之前缺少单引号。