首页 > 数据库 > Access > 正文

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

2024-09-07 19:05:00
字体:
来源:转载
供稿:网友

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

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

create proc test
(
    @id        int
)
as
declare @flag int
select * from person where [email protected]
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);
        }

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

发表评论 共有条评论
用户名: 密码:
验证码: 匿名发表