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

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

    以前写的文章可能还有很多地方没说到,希望能有更多的朋友提意见,谢谢!
  • 相关阅读:
    Unity3D启动报错的解决方案
    Unity3D引用dll打包发布的问题及解决
    轻量级C#网络通信组件StriveEngine —— C/S通信开源demo(附源码)
    k8s 各种网络方案
    网络模型
    管理和安装 chart
    开发自己的 chart
    再次实践 MySQL chart
    chart 模板
    chart 目录结构
  • 原文地址:https://www.cnblogs.com/pw/p/429455.html
Copyright © 2020-2023  润新知