zoukankan      html  css  js  c++  java
  • 使用Data Access Application Block 得到存储过程的返回值

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

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

    以前写的文章可能还有很多地方没说到,希望能有更多的朋友提意见,谢谢!
  • 相关阅读:
    关于白盒测试的心得
    基于Java的闰年测试
    等价类划分练习的代码实现
    软件测试中的等价类划分练习
    关于软件测试的初学小结
    现代软件工程作业第十二题(原十四题)
    好像木有白盒测试实验的报告,补一个~
    给大家推荐一本书啊啊~
    关于【做一名软件测试工程师,需要具备什么】的我的看法
    关于考试的笔记整理
  • 原文地址:https://www.cnblogs.com/pw/p/429455.html
Copyright © 2011-2022 走看看