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

2024-12-04 04:48:19
推荐回答(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是一个列。