sp_executeSql 用法 执行有参数的sql字符串 出现必须声明标量变量 "@XXX"。

今天遇到了一个难题 就是把 一个拼接sql语句 的返回值 赋值给一个变量

经研究 要用sp_executeSql这个存储过程 据说是从sql 2005才开始有的

代码如下:

declare @str nvarchar(1000)
declare @fld varchar(20)
declare @tbl varchar(20)
declare @MaxID varchar(20)
set @fld='id'
set @tbl ='test'

set @str ='select @maxID=isnull(MAX('+@fld+'),0)+1 from '+@tbl

exec sp_executeSql @str,N'@maxID int out ',@MaxID output

print(@maxid)

看了 F1 帮助 没看明白 后来从网上搜了下看到Jeff Gao的博客园里

(网址:http://www.cnblogs.com/0banana0/archive/2012/03/19/2406120.html)

有类似的文章 看了一下 终于明白了 又自己测试了下 还真的可以了 

如上代码 需注意的是 @tbl必须是拼出来的 sql语句变量必须是nvarchar 类型

原文地址:https://www.cnblogs.com/SoftWareIe/p/4464075.html