C#事务

1、创建事务的结构
[csharp]  view plain copy print ?
  1. SqlConnection   sqlConnection   =   new   SqlConnection();     
  2.   //  初始化连接     
  3.   //   开启事务     
  4.   SqlTransaction   sqlTransaction   =   sqlConnection.BeginTransaction();     
  5.   //   将事务应用于Command     
  6.   SqlCommand   sqlCommand   =   new   SqlCommand();     
  7.   sqlCommand.Connection   =   sqlConnection;     
  8.   sqlCommand.Transaction   =   sqlTransaction;       
  9.   try     
  10.   {     
  11.   //   利用sqlcommand进行数据操作        
  12.   //   成功提交     
  13.   sqlTransaction.Commit();     
  14.   }     
  15.   catch(Exception   ex)     
  16.   {     
  17.   //   出错回滚     
  18.   sqlTransaction.Rollback();     
  19.   }    
2、简单例子
[csharp]  view plain copy print ?
  1. {     
  2.         DataTable   dt   =   new   DataTable();     
  3.         System.Data.SqlClient.SqlConnection   cnn= new  System.Data.SqlClient.SqlConnection("连接字符串");     
  4.         System.Data.SqlClient.SqlCommand   cm   =   new   System.Data.SqlClient.SqlCommand();     
  5.         cm.Connection   =   cnn;     
  6.         cnn.Open();     
  7.         System.Data.SqlClient.SqlTransaction   trans   =   cnn.BeginTransaction();     
  8.         try     
  9.         {     
  10.                 foreach(DataRow   dr   in   dt.Rows)     
  11.                 {    
  12.                      cm.CommandText   = "update [表] set [数量] = @amount where   productID   =   @productID";     
  13.                         cm.Parameters.Add("@amount",SqlDbType.Int);     
  14.                         cm.Parameters["@amount"].Value   =   Convert.ToInt32(dr["amount"]);     
  15.                         cm.Parameters.Add("@productID",SqlDbType.VarChar);     
  16.                         cm.Parameters["@productID"].Value   =   dr["productID"].ToString();     
  17.                         cm.ExecuteNonQuery();     
  18.                 }     
  19.                 trans.Commit();     
  20.         }     
  21.         catch     
  22.         {     
  23.                 trans.Rollback();     
  24.         }     
  25.         finally     
  26.         {     
  27.                 cnn.Close();     
  28.                 trans.Dispose();     
  29.                 cnn.Dispose();     
  30.         }     
  31. }  
3、SQl server中的事务例子
[csharp]  view plain copy print ?
  1. begin transaction   
  2. save transaction A  
  3. insert into demo values('BB','B term')  
  4. rollback TRANSACTION A  
  5. create table demo2(name varchar(10),age int)  
  6. insert into demo2(name,age) values('lis',1)  
  7. rollback transaction  
  8.   insert into demo values('BB','B term')  
  9.  commit TRANSACTION A  
  10.  commit TRANSACTION    

4、注意
  1。事务必须在连接打开后BeginTransaction();
  2.事务添加到SqlCommand(sqlCommand.Transaction   =   sqlTransaction;   )
  3、其他数据库对应做相应调整
  4、可以用微软提供的一个dll,很方便
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值