SQL SERVER 中把表名作为参数传递给存储过程后,怎么把表中的数据赋值给存储过程的变量?

2024年12月04日 04:48
有4个网友回答
网友(1):

获取结果不是这么写的

可以用下面这种写法:
DECLARE @T INT;
DECLARE @Sql NVARCHAR(200);
set @Sql = 'SELECT @T = START FROM ' + @TABLENAME + ' WHERE ...';
EXEC SP_EXECUTESQL @Sql, N'@T INT OUTPUT', @T OUTPUT;

网友(2):

在各关键词之间没有加空格分隔开 SELECT,FROM, WHERE前后都需要有空格
EXEC ('SELECT '+@T+'=START FROM '+@TABLENAME+' WHERE....)

网友(3):

为什么要加“‘’”,在数据库中‘’是字符型的,去掉‘’和+

网友(4):

@T 是一个变量,start是一个列。