sp_executeSql 用法

今天遇到了一个难题 就是把 一个拼接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 类型

 

郑重声明:本站内容如果来自互联网及其他传播媒体,其版权均属原媒体及文章作者所有。转载目的在于传递更多信息及用于网络分享,并不代表本站赞同其观点和对其真实性负责,也不构成任何其他建议。