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

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

    以前写的文章可能还有很多地方没说到,希望能有更多的朋友提意见,谢谢!
  • 相关阅读:
    【转载】uboot的工具mkimage使用方法
    u-boot-2010.3移植到Tiny6410问题总结
    【转载】 GNU GCC 选项说明
    【转载】GCC 预处理器选项
    用kermit通过串口往nandflash任意地址里烧写任何文件!
    自己写Tiny6410的Bootloader总结!
    ARM常用汇编指令介绍
    Ubuntu14.04和Tiny6410挂载NFS服务!
    Tiny 6410的Linux学习总结!
    Tiny6410下的第一个Linux驱动程序
  • 原文地址:https://www.cnblogs.com/pw/p/429455.html
Copyright © 2020-2023  润新知