Warning: file_get_contents(/data/phpspider/zhask/data//catemap/7/sql-server/24.json): failed to open stream: No such file or directory in /data/phpspider/zhask/libs/function.php on line 167

Warning: Invalid argument supplied for foreach() in /data/phpspider/zhask/libs/tag.function.php on line 1116

Notice: Undefined index: in /data/phpspider/zhask/libs/function.php on line 180

Warning: array_chunk() expects parameter 1 to be array, null given in /data/phpspider/zhask/libs/function.php on line 181
sp_executesql参数值_Sql_Sql Server_Tsql_Dynamic Sql - Fatal编程技术网

sp_executesql参数值

sp_executesql参数值,sql,sql-server,tsql,dynamic-sql,Sql,Sql Server,Tsql,Dynamic Sql,我有一个可以由用户修改的表,这意味着用户可以添加列,因为我不知道de table将有多少列,我不知道如何提供sp_executesql值 到目前为止,我的代码是: SET @sSQL = ( N'INSERT INTO dbo.MyTable VALUES('+@numParametros+')' ) --For Explaining purposes since @stmtPar is SET dynamically --in a while-loop at de begi

我有一个可以由用户修改的表,这意味着用户可以添加列,因为我不知道de table将有多少列,我不知道如何提供sp_executesql值

到目前为止,我的代码是:

SET @sSQL = (
    N'INSERT INTO dbo.MyTable
    VALUES('+@numParametros+')'
)

--For Explaining purposes since @stmtPar is SET dynamically 
--in a while-loop at de begining of the SP
SET @ParmDefinition = @stmtPar 
这里是我需要帮助的地方,因为我不知道这个表有多少列,我不知道我需要提供多少@参数

EXEC sp_executesql @sSql, @ParmDefinition, ????
我有一个@values变量,它包含需要插入的值,但是如果我放入下一个station,sql只使用@values来提供第一列

EXEC sp_executesql @sSql, @ParmDefinition, @values

希望您能提供帮助,谢谢

如果您不知道应该手动构建SQL语句的参数数量。下面是一个示例(第三列为varchar类型,使用了双配额):


如果不知道参数的数量,则应手动生成SQL语句。下面是一个示例(第三列为varchar类型,使用了双配额):

DECLARE @sSQL NVARCHAR(MAX);
DECLARE @numParametros NVARCHAR(MAX);

SET @numParametros = '1,2,''test''';

SET @sSQL = (
    N'INSERT INTO Table1
    VALUES('+@numParametros+')'
)
exec sp_executesql @sSQL