我正在创建存储过程,我需要动态地构建一个临时表。我尝试了下面的代码,但没有创建表。当我在查询窗口中执行生成的查询时,它在那里正常工作。为什么不是从存储过程内创建表?
--declare query variable
DECLARE @Query nvarchar(MAX)
SET @Query = 'CREATE TABLE #final (DATE int,'
--DECLARE @COLUMNNAME VARIABLE
DECLARE @ColName nvarchar(10)
OPEN @taCur
FETCH NEXT FROM @taCur INTO @ColName
WHILE (@@FETCH_STATUS = 0)
BEGIN
SET @Query = @Query + 'T_' + @ColName +' int,'
FETCH NEXT FROM @taCur INTO @ColName
END
SET @Query = @Query + 'TOTAL int,CUMM_TOTAL int)'
print @Query
EXEC sp_executesql @Query
--SET @Query = 'INSERT INTO #final (DATE) VALUES (1)'
SET @Query = 'SELECT * FROM #final'
print @Query
EXEC(@Query)
最终生成创建表的查询是遵循
CREATE TABLE #final (DATE int,T_211E int,T_211G int,T_211H int,T_211J int,T_211L int,T_221F int,TOTAL int,CUMM_TOTAL int)
+1对于代码示例.. – 2012-04-28 04:10:01
谢谢@Siva ...你的回答很有帮助 – Dharmesh 2012-04-28 04:15:24