SQL SERVER 中把表名作为参数传递给存储过程后,怎么把表中的数据赋值给存储过程的变量?
CREATEPROCPRO@TABLENAMEVARCHAR(20)ASDECLARE@TINTEXEC('SELECT'+@T+'=STARTFROM'+@TABLEN...
CREATE PROC PRO
@TABLENAME VARCHAR(20)
AS
DECLARE @T INT
EXEC ('SELECT'+@T+'=START FROM '+@TABLENAME+'WHERE....)
怎么提示“=”附近有错误 高手帮忙啊 展开
@TABLENAME VARCHAR(20)
AS
DECLARE @T INT
EXEC ('SELECT'+@T+'=START FROM '+@TABLENAME+'WHERE....)
怎么提示“=”附近有错误 高手帮忙啊 展开
4个回答
展开全部
获取结果不是这么写的
可以用下面这种写法:
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;
可以用下面这种写法:
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;
参考资料: http://hi.baidu.com/wangzhiqing999/blog/item/6f6da5fee476db869f51465d.html
本回答被提问者和网友采纳
已赞过
已踩过<
评论
收起
你对这个回答的评价是?
展开全部
在各关键词之间没有加空格分隔开 SELECT,FROM, WHERE前后都需要有空格
EXEC ('SELECT '+@T+'=START FROM '+@TABLENAME+' WHERE....)
EXEC ('SELECT '+@T+'=START FROM '+@TABLENAME+' WHERE....)
已赞过
已踩过<
评论
收起
你对这个回答的评价是?
展开全部
为什么要加“‘’”,在数据库中‘’是字符型的,去掉‘’和+
已赞过
已踩过<
评论
收起
你对这个回答的评价是?
展开全部
@T 是一个变量,start是一个列。
已赞过
已踩过<
评论
收起
你对这个回答的评价是?
推荐律师服务:
若未解决您的问题,请您详细描述您的问题,通过百度律临进行免费专业咨询