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

王朝other·作者佚名  2006-11-24
窄屏简体版  字體: |||超大  

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

1、首先建立一个具有返回值的存储过程,作为示例,我就简单的建一个存储过程,如下:

create proc test

(

@id int

)

as

declare @flag int

select * from person where id=@id

if @@rowcount > 0

set @flag=1

else

set @flag=0

return @flag

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

[TestMethod]

public void TestReturnValue()

{

Database db = DatabaseFactory.CreateDatabase();

DbCommand dbcomm = db.GetStoredProcCommand("test");

db.AddInParameter(dbcomm, "@id", DbType.Int32,1);

//关键在这里,添加一个参数,类型为ReturnValue

db.AddParameter(dbcomm, "@RETURN_VALUE", DbType.String, ParameterDirection.ReturnValue, "", DataRowVersion.Current, null);

db.ExecuteNonQuery(dbcomm);

int testvalue = (int)dbcomm.Parameters["@RETURN_VALUE"].Value;

Assert.AreEqual(testvalue, 1);

}

通过上面的代码我们就能够在程序中获得存储过程的返回值了。以前写的文章可能还有很多地方没说到,希望能有更多的朋友提意见,谢谢!

 
 
 
免责声明:本文为网络用户发布,其观点仅代表作者个人观点,与本站无关,本站仅提供信息存储服务。文中陈述内容未经本站证实,其真实性、完整性、及时性本站不作任何保证或承诺,请读者仅作参考,并请自行核实相关内容。
 
 
© 2005- 王朝網路 版權所有 導航