• 使用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);
            }

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

    以前写的文章可能还有很多地方没说到,希望能有更多的朋友提意见,谢谢!
  • 相关阅读:
    ci框架——文章查看之上篇下篇
    ci框架——分页
    ci框架——数据库(增删改查)
    全选和反选
    基于CI框架的管理系统
    在dedecms系统下, 改写火车头的入库接口 写一个接口文件运行一次自动读取 http://news.163.com/rank/
    缩略图
    php——两种无限级分类
    webpack和webpack-dev-server安装配置(遇到各种问题的解决方法)
    python装饰器
  • 原文地址:https://www.cnblogs.com/pw/p/429455.html
Copyright © 2020-2023  润新知