使用Data Access Application Block 得到存储过程的返回值

        今天有位朋友问我如何在Data Access Application Block中得到存储的过程的返回值,我才发现自己以前写的文章中确实没提到这方面的问题,现在来补充一下,具体的解决方法如下:

1、首先建立一个具有返回值的存储过程,作为示例,我就简单的建一个存储过程,如下:
None.gif create   proc  test
None.gif(
None.gif    
@id          int
None.gif)
None.gif
as
None.gif
None.gif
declare   @flag   int
None.gif
None.gif
select   *   from  person  where  id = @id
None.gif
None.gif
if   @@rowcount   >   0
None.gif    
set   @flag = 1
None.gif
else
None.gif    
set   @flag = 0
None.gif
None.gif
return   @flag

我们要在程序中获得这个返回值的方法如下:

None.gif         [TestMethod]
None.gif        
public   void  TestReturnValue()
ExpandedBlockStart.gifContractedBlock.gif        
dot.gif {
InBlock.gif            Database db 
= DatabaseFactory.CreateDatabase();
InBlock.gif
InBlock.gif            DbCommand dbcomm 
= db.GetStoredProcCommand("test");
InBlock.gif
InBlock.gif            db.AddInParameter(dbcomm, 
"@id", DbType.Int32,1);
InBlock.gif            
//关键在这里,添加一个参数,类型为ReturnValue
InBlock.gif
            db.AddParameter(dbcomm, "@RETURN_VALUE", DbType.String, ParameterDirection.ReturnValue, "", DataRowVersion.Current, null);
InBlock.gif            db.ExecuteNonQuery(dbcomm);
InBlock.gif
InBlock.gif            
int testvalue = (int)dbcomm.Parameters["@RETURN_VALUE"].Value;
InBlock.gif
InBlock.gif            Assert.AreEqual(testvalue, 
1);
ExpandedBlockEnd.gif        }

通过上面的代码我们就能够在程序中获得存储过程的返回值了。

以前写的文章可能还有很多地方没说到,希望能有更多的朋友提意见,谢谢!

转载于:https://www.cnblogs.com/pw/archive/2006/06/19/429455.html

评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值
>