我正在尝试将 TABLE 变量传递给 sp_executesql 过程:
DECLARE @params NVARCHAR(MAX)
SET @params = '@workingData TABLE ( col1 VARCHAR(20),
col2 VARCHAR(50) )'
EXEC sp_executesql @sql, @params, @workingData
我得到错误:
Msg 156, Level 15, State 1, Line 1
Incorrect syntax near the keyword 'TABLE'.
我尝试在“TABLE”之后省略列规范。我还尝试将表声明为动态 SQL 中的变量。但没有运气...
在我看来,不允许在此过程中将 TABLE 变量作为参数传递?顺便说一句:我正在运行 MSSQL2008 R2。
我对使用像 #workingData 这样的本地临时表不感兴趣,因为我从另一个过程加载工作数据:
INSERT INTO @workingData
EXEC myProc @param1, @param2
我不能直接进入临时变量(对吗?)......
任何帮助表示赞赏!