• C#调用带返回值的存储过程


    (1)在SQL Server中建立如下的存储过程:

    set ANSI_NULLS ON
    set QUOTED_IDENTIFIER ON
    GO
    CREATE PROCEDURE [dbo].[GetNameById]
     @studentid varchar(8),
     @studentname nvarchar(50) OUTPUT
    AS
    BEGIN
     SELECT @studentname=studentname FROM student
        WHERE studentid=@studentid
     if @@Error<>0
      RETURN -1
     else
      RETURN 0 
    END
    该存储过程的作用是根据学号,获取姓名,并使用RETURN关键字来返回值。

    如果要在SQL Server的查询分析器中执行该存储过程,对应的SQL语句如下:

    Declare  @studentname nvarchar(50),
    exec GetNameById @studentname output@id=2
    select @studentname

    select @@Error

    (2)编写C#代码:

               using (SqlConnection conn = new SqlConnection(connStr))
                {
                    try
                    {
                        SqlCommand cmd = new SqlCommand("GetNameById", conn);
                        cmd.CommandType = CommandType.StoredProcedure;
                        cmd.Parameters.AddWithValue("@studentid", "09888888");  //给输入参数赋值
                        SqlParameter parOutput =cmd.Parameters.Add("@studentname", SqlDbType.NVarChar, 50);  //定义输出参数
                        parOutput.Direction = ParameterDirection.Output;  //参数类型为Output
                        SqlParameter parReturn = new SqlParameter("@return", SqlDbType.Int);
                        parReturn.Direction = ParameterDirection.ReturnValue;   //参数类型为ReturnValue                    cmd.Parameters.Add(parReturn);
                        conn.Open();
                        cmd.ExecuteNonQuery();
                        MessageBox.Show(parOutput.Value.ToString());   //显示输出参数的值
                        MessageBox.Show(parReturn.Value.ToString());  //显示返回值
                    }
                    catch (System.Exception ex)
                    {
                        MessageBox.Show(ex.Message);
                    }
                }

    上面的@return是临时参数,用于获取存储过程的返回值,这个参数名称可以是任意的。

  • 相关阅读:
    Service Mesh 在百度网盘数万后端的落地实践
    垃圾回收GC3种算法的衍生品 增量回收:预测和控制GC所产生的中断时间
    cv_list
    段式内存管理
    页式内存管理
    基本内存管理
    内存抖动
    内存管理 垃圾回收 C语言内存分配 垃圾回收3大算法 引用计数3个缺点
    DEDECMS后台传附件图片出现Upload filetype not allow解决办法
    浅谈dedecms模板引擎工作原理及自定义标签
  • 原文地址:https://www.cnblogs.com/zhouhb/p/1965902.html
Copyright © 2020-2023  润新知