asp.net 读取sql存储过程返回值

关于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' 的参数”.

         读存储过程示例:

 

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/wwy224y/p/3619738.html

评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

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

余额充值