读取exec返回值

读查询语句示例:
     Declare @count int

1    set @strSql=N'select @a= count(*) from ['+ @tblName + '] where  1=1 '+   @strWhere
2    exec sp_executesql  @strSql ,N'@a int output',@Count output
3    select @Count
    
要点:
 1.利用系统存储过程 sp_executesql
 2. 在要执行的Sql文中加入参数,如 "@a",在sp_executesql的参数  声 明中要指定参数的类型,参数的方向。
 3. sp_executesql的每个字符类型的参数都要是 n开头的数据类型,如是nvarchar 不能是      varchar,否则会报错 “过程需要类型为 'ntext/nchar/nvarchar' 的参数”.

exec sp_executesql @rc,N'@a int output,@b int output',@cstucount output,@ccount output

  读存储过程示例:

create procedure ProTest
(
         @name varchar(10),
         @money int output
)
as
begin
        if(@name='1')
                  set @money=1000
        else
                  set @money=2000
end

这个只是一个简单的示例,这个存储过程返回的是@money 这个参数的值,那么当我们在另外一个存储过程中调用此存储过程的时候如何获取这个参数呢,方法如下:


declare @m int ---用来接收返回值的变量
exec ProTest @name='1',@money=@m output --一定要注名是output

就这么简单,我们就获得了返回值,然后就可以利用它了

转载于:https://www.cnblogs.com/gxh973121/archive/2009/04/06/1430167.html

  • 0
    点赞
  • 0
    评论
  • 0
    收藏
  • 扫一扫,分享海报

参与评论 您还未登录,请先 登录 后发表或查看评论
©️2022 CSDN 皮肤主题:编程工作室 设计师:CSDN官方博客 返回首页
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、C币套餐、付费专栏及课程。

余额充值