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

80酷酷网    80kuku.com

  access|application|存储过程

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

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

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

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

分享到
  • 微信分享
  • 新浪微博
  • QQ好友
  • QQ空间
点击: