zoukankan      html  css  js  c++  java
  • 关于ExecuteNonQuery执行存储过程的返回值 、、实例讲解存储过程的返回值与传出参数、、、C#获取存储过程的 Return返回值和Output输出参数值

     

     

    关于ExecuteNonQuery执行存储过程的返回值

    用到过ExecuteNonQuery()函数的朋友们在开发的时候肯定这么用过.

    if(cmd.ExecuteNonQuery("xxxx")>0)

    {

         //执行成功!

    }

    else

    {

         //执行失败!

    }

    通过ExecuteNonQuery()的返回值来判断操作数据库的成功与否是可以的.但是要分情况.

    1.ExecuteNonQuery() 不执行存储过程.

    此时如果对数据库执行,插入,更新,删除操作,返回的是 受影响的行数.(及一个大于等于0的整数)

    2.ExecuteNonQuery() 执行查询不返回影响的行数.

    2.ExecuteNonQuery   执行存储过程.

    [1].存储过程有返回值(传出参数)

        (1).把数据库中受影响的行数赋给返回值,这是得到的返回值是受影响的函数(大于或等于0的整数).

        (2).把某个值赋给返回值.

    [2].存储过程没有返回值

        执行成功后返回 -1.

    (没有返回值的存储过程理应 返回 受影响的行数 (执行 增删改) 但是.但我们在ado.net中执行存储过程的时候,dotnet 自动为给了存储过程一个默认值:set nocount on;

    所以给我们的感觉是执行存储过程默认返回 -1  )

    ============================================================================

    1、执行存储过程
        
       
       SqlConnection conn = new SqlConnection();//建立连接


                conn.ConnectionString = Config.ConnStr;//连接字符串


                conn.Open();//打开连接
                SqlCommand cmd = new SqlCommand();//创建命令
                cmd.Connection = conn;//指定连接
                cmd.CommandText = "PRO_AAA";//存储过程名称
                cmd.CommandType = CommandType.StoredProcedure;//指定命令的类型是存储过程
                cmd.ExecuteNonQuery();//执行
                conn.Close();//关闭连接




    2、无返回


    同上


    3、获得返回结果:


    指定一个参数,这个参数的方向(“Direction”)是“ReturnValue”。


    MyCommand.Parameters.Add(new SqlParameter("@return", SqlDbType.Int));
    MyCommand.Parameters["@return"].Direction = ParameterDirection.ReturnValue;
    MyCommand.ExecuteNonQuery();
    Response.Write(MyCommand.Parameters["@return"].Value.ToString());




    4、获得返回的表:


    用SqlDataAdapter 执行Command,然后填充到表。


    SqlCommand cmd = new SqlCommand("proc_3", con);//同上
    cmd.CommandType = CommandType.StoredProcedure;//同上
    SqlDataAdapter da = new SqlDataAdapter(cmd);//用SqlDataAdapter执行
    DataTable table = new DataTable();//创建一张表
    da.Fill(table);//填充表
    return table;

    参考:

    【按:我是为了获得“Return返回值”搜索到第2和第3篇文章的,但是他们都没有找到解决办法,用的是OUTPUR输出。只有第一个是真正的解决办法。】

    C#获取存储过程的 Return返回值和Output输出参数值
    http://www.2cto.com/kf/201007/52892.html

    ASP.NET调用存储过程并接收存储过程返回值  

    http://duanxifeng123.blog.163.com/blog/static/11542723201072112617414/?fromdm&fromSearch&isFromSearchEngine=yes

    为什么存储过程总返回-1 取存储过程的值 取数据集

    http://liu.wf.blog.163.com/blog/static/237887452009102335512300/

    ==========================================================================

    实例讲解存储过程的返回值与传出参数

     
    发布时间:2008.05.07 04:40     来源:赛迪网    作者:小乔

     

    【赛迪网-IT技术报道】存储过程可以有返回值,可以有传出参数。传出参数的数量没有限制,返回值只能有一个,并且执行return 以后,和其他语言的函数中一样,后面的语句就不会再执行了。所以该怎么用,还需要自己来权衡。

    下面是获取返回值和传出参数的例子:

    SqlConnection conn=new SqlConnection ( System.Configuration.ConfigurationManager.AppSettings["ConnectionString"]);

    SqlCommand comm = new SqlCommand("ReturnValueTest",conn);

    comm.Parameters.Add("@name", SqlDbType.NVarChar,100).Value ="chitu";

    comm.Parameters.Add("@returnTest",SqlDbType.Int );

    comm.Parameters.Add ("returnValue",SqlDbType.Int);

    comm.Parameters["@returnTest"].Direction =ParameterDirection.Output;

    comm.Parameters["returnValue"].Direction = ParameterDirection.ReturnValue;

    comm.CommandType = CommandType.StoredProcedure;

    conn.Open();

    comm.ExecuteNonQuery();

    conn.Close();

    int a =(int) comm.Parameters["@returnTest"].Value;

    int b = (int)comm.Parameters["returnValue"].Value;

    返回值和传出参数彼此的作用还是无法替代的。(责任编辑:卢兆林)

    =====================================================================

    C#获取存储过程的 Return返回值和Output输出参数值
    2010-07-11 14:34:36     我来说两句      
    收藏    我要投稿

    1.获取Return返回值

     程序代码

    //存储过程
    //Create PROCEDURE MYSQL
    //     @a int,
    //     @b int
    //AS
    //     return @a + @b
    //GO
    SqlConnection conn = new SqlConnection(ConfigurationManager.ConnectionStrings["LocalSqlServer"].ToString());
    conn.Open();
    SqlCommand MyCommand = new SqlCommand("MYSQL", conn);
    MyCommand.CommandType = CommandType.StoredProcedure;
    MyCommand.Parameters.Add(new SqlParameter("@a", SqlDbType.Int));
    MyCommand.Parameters["@a"].Value = 10;
    MyCommand.Parameters.Add(new SqlParameter("@b", SqlDbType.Int));
    MyCommand.Parameters["@b"].Value = 20;
    MyCommand.Parameters.Add(new SqlParameter("@return", SqlDbType.Int));
    MyCommand.Parameters["@return"].Direction = ParameterDirection.ReturnValue;
    MyCommand.ExecuteNonQuery();
    Response.Write(MyCommand.Parameters["@return"].Value.ToString());


    2.获取Output输出参数值

     程序代码

    //存储过程
    //Create PROCEDURE MYSQL
    //     @a int,
    //     @b int,
    //     @c int output
    //AS
    //     Set @c = @a + @b
    //GO
    SqlConnection conn = new SqlConnection(ConfigurationManager.ConnectionStrings["LocalSqlServer"].ToString());
    conn.Open();
    SqlCommand MyCommand = new SqlCommand("MYSQL", conn);
    MyCommand.CommandType = CommandType.StoredProcedure;
    MyCommand.Parameters.Add(new SqlParameter("@a", SqlDbType.Int));
    MyCommand.Parameters["@a"].Value = 20;
    MyCommand.Parameters.Add(new SqlParameter("@b", SqlDbType.Int));
    MyCommand.Parameters["@b"].Value = 20;
    MyCommand.Parameters.Add(new SqlParameter("@c", SqlDbType.Int));
    MyCommand.Parameters["@c"].Direction = ParameterDirection.Output;
    MyCommand.ExecuteNonQuery();
    Response.Write(MyCommand.Parameters["@c"].Value.ToString());

    ---------------------------------------------------------------------------------------------------------------

    以下代码转自网络:

    C#接收存储过程返回值:

         public static int User_Add(User us)
         {
             int iRet;
             SqlConnection conn = new SqlConnection(Conn_Str);
             SqlCommand cmd = new SqlCommand("User_Add", conn);
             cmd.CommandType = CommandType.StoredProcedure;
             cmd.Parameters.AddWithValue("@UName", us.UName);
             cmd.Parameters.AddWithValue("@UPass", us.UPass);
             cmd.Parameters.AddWithValue("@PassQuestion", us.PassQuestion);
             cmd.Parameters.AddWithValue("@PassKey", us.PassKey);
             cmd.Parameters.AddWithValue("@Email", us.Email);
             cmd.Parameters.AddWithValue("@RName", us.RName);
             cmd.Parameters.AddWithValue("@Area", us.Area);
             cmd.Parameters.AddWithValue("@Address", us.Address);
             cmd.Parameters.AddWithValue("@ZipCodes", us.ZipCodes);
             cmd.Parameters.AddWithValue("@Phone", us.Phone);
             cmd.Parameters.AddWithValue("@QQ", us.QQ);
             cmd.Parameters.Add("@RETURN_VALUE", "").Direction = ParameterDirection.ReturnValue;       
             try
             {
                 conn.Open();
                 cmd.ExecuteNonQuery();
                 iRet = (int)cmd.Parameters["@RETURN_VALUE"].Value;
             }
             catch (SqlException ex)
             {
                 throw ex;
             }
             finally
             {
                 conn.Close();
             }
             return iRet;
         }

    C#接收存储过程输出参数:

        public static decimal Cart_UserAmount(int UID)
        {
            decimal iRet;
            SqlConnection conn = new SqlConnection(Conn_Str);
            SqlCommand cmd = new SqlCommand("Cart_UserAmount", conn);
            cmd.CommandType = CommandType.StoredProcedure;
            cmd.Parameters.AddWithValue("@UID", UID);
            cmd.Parameters.Add("@Amount", SqlDbType.Decimal).Direction=ParameterDirection.Output;
            try
            {
                conn.Open();
                cmd.ExecuteNonQuery();
                iRet = (decimal)cmd.Parameters["@Amount"].Value;
            }
            catch (SqlException ex)
            {
                throw ex;
            }
          &n

    =========================================================

    asp.net/C# 执行存储过程技术要点,获取Return返回值,解决“存储过程总返回-1”的问题

     

    1、执行存储过程
        
       
       SqlConnection conn = new SqlConnection();//建立连接


                conn.ConnectionString = Config.ConnStr;//连接字符串


                conn.Open();//打开连接
                SqlCommand cmd = new SqlCommand();//创建命令
                cmd.Connection = conn;//指定连接
                cmd.CommandText = "PRO_AAA";//存储过程名称
                cmd.CommandType = CommandType.StoredProcedure;//指定命令的类型是存储过程
                cmd.ExecuteNonQuery();//执行
                conn.Close();//关闭连接




    2、无返回


    同上


    3、获得返回结果:


    指定一个参数,这个参数的方向(“Direction”)是“ReturnValue”。


    MyCommand.Parameters.Add(new SqlParameter("@return", SqlDbType.Int));
    MyCommand.Parameters["@return"].Direction = ParameterDirection.ReturnValue;
    MyCommand.ExecuteNonQuery();
    Response.Write(MyCommand.Parameters["@return"].Value.ToString());




    4、获得返回的表:


    用SqlDataAdapter 执行Command,然后填充到表。


    SqlCommand cmd = new SqlCommand("proc_3", con);//同上
    cmd.CommandType = CommandType.StoredProcedure;//同上
    SqlDataAdapter da = new SqlDataAdapter(cmd);//用SqlDataAdapter执行
    DataTable table = new DataTable();//创建一张表
    da.Fill(table);//填充表
    return table;

    参考:

    【按:我是为了获得“Return返回值”搜索到第2和第3篇文章的,但是他们都没有找到解决办法,用的是OUTPUR输出。只有第一个是真正的解决办法。】

    C#获取存储过程的 Return返回值和Output输出参数值
    http://www.2cto.com/kf/201007/52892.html

    ASP.NET调用存储过程并接收存储过程返回值  

    http://duanxifeng123.blog.163.com/blog/static/11542723201072112617414/?fromdm&fromSearch&isFromSearchEngine=yes

    为什么存储过程总返回-1 取存储过程的值 取数据集

    http://liu.wf.blog.163.com/blog/static/237887452009102335512300/

    流浪是注定的宿命;
    漂泊是无尽的轮回。
     
  • 相关阅读:
    Java 包装类的自动封箱与拆箱
    Java 基本类型的包装类
    Java日期时间练习三(闰年)
    导入包与模块
    模块_os模块
    Re模块练习题
    Re模块的方法补充
    Re模块的 三个方法
    基础纹理
    ruby 的数组操作
  • 原文地址:https://www.cnblogs.com/meimao5211/p/3384233.html
Copyright © 2011-2022 走看看