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

编辑Tag赚U币
教程Tag:暂无Tag,欢迎添加,赚取U币!

推荐:ASP.NET2.0服务器控件之捕获回传事件
1、实现捕获回传事件 如果服务器控件需要捕获来自客户端的回传事件,并想为该回传事件自定义服务器端事件处理逻辑,那么控件必须实现 System.Web.UI.IPostBackEventHandler接口。下面列举了该

今天有位朋友问我如何在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);
}

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

分享:ASP.NET的底层的工作机制介绍
关于ASP.NET的底层的工作机制,最近园子里讨论的甚是火热。相信很多人都看过Rick Strahl先生的一篇经典之作:A low-level Look at the ASP.NET Architecture,经Rick Strahl同意,我把他的这篇

来源:模板无忧//所属分类:.Net教程/更新时间:2008-08-22
相关.Net教程