在存储过程中执行动态sql后的返回值的问题
来源:网络 责任编辑:栏目编辑 发表时间:2013-07-01 03:53 点击:次
在存储过程中执行动态sql后的返回值的问题
declare @ret int
exec ('select @ret=12')
print @ret
出现错误:
必须声明标量变量"@ret"。
declare @ret int
exec sp_executesql N'select @ret=12',N'@ret int out',@ret out
print @ret
declare @ret int
declare @sql nvarchar(1000)
select @sql=N'select @ret=12'
exec sp_executesql @sql,N'@ret int out',@ret out
print @ret
注意,@sql一定要定义为nvarchar,而不能定义为varchar,否则出现:
过程需要类型为'ntext/nchar/nvarchar' 的参数'@statement'。
摘自 布谷鸟的专栏
declare @ret int
exec ('select @ret=12')
print @ret
出现错误:
必须声明标量变量"@ret"。
declare @ret int
exec sp_executesql N'select @ret=12',N'@ret int out',@ret out
print @ret
declare @ret int
declare @sql nvarchar(1000)
select @sql=N'select @ret=12'
exec sp_executesql @sql,N'@ret int out',@ret out
print @ret
注意,@sql一定要定义为nvarchar,而不能定义为varchar,否则出现:
过程需要类型为'ntext/nchar/nvarchar' 的参数'@statement'。
摘自 布谷鸟的专栏
最新推荐更多>>>
- 发表评论
-
- 最新评论 更多>>