1 , 在介绍Sql Server 的事务之前 , 我想先谈谈.net中利用System.Data.SqlClient里面的相关类 , 实现事务.春节福利啊SQL事务_ 事务

         public void ProTranandler()
        {
            using (SqlConnection conn = new SqlConnection(this.CONN_LINK))
            {
                conn.Open();
                SqlTransaction tran = conn.BeginTransaction();
                SqlCommand scd = new SqlCommand();
                scd.Connection = conn;
                //--------------------------------------------------------------
                //--------------调用"存储过程"
                //scd.CommandText = "ProSql";
                //scd.CommandType = CommandType.StoredProcedure;
                //SqlParameter sqtIN = new SqlParameter("@inParam", SqlDbType.Int);
                //sqtIN.Direction = ParameterDirection.Input;
                //sqtIN.Value = 1;
                //SqlParameter sqtOUT = new SqlParameter("@ok", SqlDbType.Int);
                //sqtOUT.Direction = ParameterDirection.Output;
                //scd.Parameters.Add(sqtIN);
                //scd.Parameters.Add(sqtOUT);
                try
                {
                    scd.Transaction = tran;
                    scd.CommandText = "SQL1";
                    scd.ExecuteNonQuery();
                    scd.CommandText = "SQL2";
                    scd.ExecuteNonQuery();
                    tran.Commit();
                }
                catch (Exception e)
                {
                    tran.Rollback();
                    Console.WriteLine(e.Message);
                }
                finally
                {
                    scd.Dispose();
                    conn.Close();
                }
            }
        }

注意 : SQL1 和SQL2要么都执行 , 要么都不执行.但只不是最好的方案 , 我喜欢用SQL的事务,优点是不需要编译,执行速度快 , 代码集成重用性高.

 create proc ProTest
@InParam int ,
@InParamStr varChar(50),
@OutParam int output
as
 begin tran
  declare @error int
  set @error = 0
  --SQL1
  set @error = @@ERROR + @error
  --SQL2
  set @error = @@ERROR + @error
  if @error > 0 
  begin
   set @OutParam = 0
   rollback tran
  end
   
  else
  begin
   set @OutParam = 1
   commit tran
  end

 

上面的注释代码 , 解释了如何调用