zoukankan      html  css  js  c++  java
  • C#存储过程中传入传出参数

     作者:卞功鑫  ,转载请保留http://www.cnblogs.com/BinBinGo/p/6399847.html 

                //1   连接字符串
                string connectionString
                    = "server=127.0.0.1;integrated security=true;database=MSPetShop4";
                // = "server=.;uid=sa;pwd=SQL@5;database=AdventureWorks2012";
                // = "server=.;user id=sa;password=SQL@5;database=AdventureWorks2012";
                //2 实例化数据库连接
                System.Data.SqlClient.SqlConnection connection = new SqlConnection(connectionString);
    
                //也可以先实例化
                //System.Data.SqlClient.SqlConnection connection = new SqlConnection();
                //然后再设置ConnectionString 属性.
                //connection.ConnectionString = connectionString;
    
                try
                {
                    //3 打开连接
                    connection.Open();
                    Console.WriteLine("成功连接数据计库MSPetShop4");
                    //4 数据访问对象
                    //sql字符串存储过程
    
                    string sql = "p_proc_name";
                    /*
                      create proc p_proc_name (@pin INT ,@pout INT OUTPUT)
                         AS 
                           delete FROM dbo.A
                           WHERE 客户='biangongxin' 
                         SET @pout = @pin*100;
                     
                     */
                    //SqlCommand 表示数据库要执行的sql命令
                    System.Data.SqlClient.SqlCommand command = new SqlCommand(sql, connection);
                    //告知数据库现在要执行的是存储过程
                    //默认为标准SQL语句,可以不用设置.
                    command.CommandType = CommandType.StoredProcedure;
    
                    //提供存储过程参数(传入参数) 这里的名称@pin和存储过程中的保持一致
                    System.Data.SqlClient.SqlParameter pin = new SqlParameter("@pin", System.Data.SqlDbType.Int);
                    //参数赋值
                    pin.Value = 10;
                    //将上面的参数加入command中
                    command.Parameters.Add(pin);
    
                    //提供存储过程参数(传出参数)这里的名称@pout和存储过程中的保持一致
                    System.Data.SqlClient.SqlParameter pout = new SqlParameter("@pout", System.Data.SqlDbType.Int);
    
                    //声明为传出参数 Direction 参数方向 ,默认为传入参数 ParameterDirection.Input
                    pout.Direction = ParameterDirection.Output;
    
                    //将上面的参数加入command中
                    command.Parameters.Add(pout);
    
    
                    //ExecuteNonQuery 非查询语句
                    //默认工作在自动事务之下,直接提交
                    //执行sql DML 之前,手动开启
                    System.Data.SqlClient.SqlTransaction trans =  connection.BeginTransaction();
                    //设置命令所属的事务管理
                    command.Transaction = trans;
                    int result =  command.ExecuteNonQuery();
                    Console.WriteLine(result);
    
                    //存储过程执行过之后,可以得到传出的参数(存储过程执行的时候,会把sql中的 output的这个参数的值赋值给C#中的 pout)
                   object obj = pout.Value;
    
                   int p_result = Convert.ToInt32(obj);
    
    
    
    
                    Console.Write("SQL命令已经提交,但是事务还未提交,是否继续执行(Y/N)");
                    string ans = Console.ReadLine();
                    //提交与否@pout值的返回值始终为1000,影响的只是 SQL的 DML操作
                    if (ans.Substring(0, 1).ToUpper() == "Y")
                    {
    
                        //提交事务
                        trans.Commit();
                    }
                    else
                    {
                        //回滚事务;
                        trans.Rollback();
                    }
    
    
                    Console.WriteLine("存储过程p_proc_name,执行的结果为:{0}",p_result);
                }
                catch(System.Data.SqlClient.SqlException exception)
                {
                    Console.WriteLine(exception.Message);
                }
    
                finally
                {
                    //4 注销连接
                    connection.Dispose();
                    Console.WriteLine("成功断开数据计库MSPetShop4");
                }
                Console.ReadLine();
  • 相关阅读:
    TMF大数据分析指南 Unleashing Business Value in Big Data(一)
    TMF接口标准MTOSI演进路线图
    移动端开发:使用jQuery Mobile还是Zepto
    拖动插件的一些常见问题
    前端开发资料详解
    AngularJS源码解析3:RootScope的创建过程
    AngularJS源码解析2:注入器的详解
    AngularJS源码解析1:angular自启动过程
    angular核心原理解析3:指令的执行过程
    angular核心原理解析2:注入器的创建和使用
  • 原文地址:https://www.cnblogs.com/BinBinGo/p/6399847.html
Copyright © 2011-2022 走看看