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);
            }

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

    以前写的文章可能还有很多地方没说到,希望能有更多的朋友提意见,谢谢!
  • 相关阅读:
    easy-animation | Animation for Sass
    UC手机浏览器(U3内核)相关文档整理
    视差滚动(Parallax Scrolling)的一点小心得
    MVC Filter 返回json格式
    Jquery 实现左右两侧菜单添加、移除
    .Net 发送邮件
    Request.From,Request.QueryString转对象
    DataTable转List,转对象
    SQL Table 自动生成Net底层-控制器Autofac注入
    SQL Table 自动生成Net底层-生成业务层Service
  • 原文地址:https://www.cnblogs.com/pw/p/429455.html
Copyright © 2011-2022 走看看