黑马程序员技术交流社区

标题: 关于事务 [打印本页]

作者: 邸亚星    时间: 2012-10-14 21:59
标题: 关于事务
这几天看了看事务     发现自己对这些还是很不明白
事务有哪些
如何执行事务
为什么要有事务


这些东西   有没有人能帮我解释一下

作者: 许庭洲    时间: 2012-10-15 19:53
1。如果要执行一系列的操作,而这些操作最终是以整体的原子操作的形式完成的话,事务就是必须的;
2。事务是关键业务系统开发中非常关键性的服务,对于关键性业务系统如果没有采用事务,那么这个系统可以说是不可用的;
3。从严格的定义来讲,事务是形成一个逻辑工作单位的数据库操作的汇集;
4。事务以一种可靠的,简洁的方式来解决系统运行中的各种异常问题;
5。事务具有四个基本特性:原子性,一致性,隔离性和持久性。

作者: 郭会茹    时间: 2012-10-15 20:02
1、创建事务的结构

SqlConnection   sqlConnection   =   new   SqlConnection();   
  ...初始化连接   
  //   开启事务   
  SqlTransaction   sqlTransaction   =   sqlConnection.BeginTransaction();   
  //   将事务应用于Command   
  SqlCommand   sqlCommand   =   new   SqlCommand();   
  sqlCommand.Connection   =   sqlConnection;   
  sqlCommand.Transaction   =   sqlTransaction;     
  try   
  {   
  //   利用sqlcommand进行数据操作   
  ...   
  //   成功提交   
  sqlTransaction.Commit();   
  }   
  catch(Exception   ex)   
  {   
  //   出错回滚   
  sqlTransaction.Rollback();   
  }   

2、简单例子

                  {   
                          DataTable   dt   =   new   DataTable();   
                          System.Data.SqlClient.SqlConnection   cnn   =   new   System.Data.SqlClient.SqlConnection("连接字符串");   
                          System.Data.SqlClient.SqlCommand   cm   =   new   System.Data.SqlClient.SqlCommand();   
                          cm.Connection   =   cnn;   
                          cnn.Open();   
                          System.Data.SqlClient.SqlTransaction   trans   =   cnn.BeginTransaction();   
                          try   
                          {   
                                  foreach(DataRow   dr   in   dt.Rows)   
                                  {  
                                          cm.CommandText   =   "update   [表]   set   [数量]   =   @amount   where   productID   =   @productID";   
                                          cm.Parameters.Add("@amount",SqlDbType.Int);   
                                          cm.Parameters["@amount"].Value   =   Convert.ToInt32(dr["amount"]);   
                                          cm.Parameters.Add("@productID",SqlDbType.VarChar);   
                                          cm.Parameters["@productID"].Value   =   dr["productID"].ToString();   
                                          cm.ExecuteNonQuery();   
                                  }   
                                  trans.Commit();   
                          }   
                          catch   
                          {   
                                  trans.Rollback();   
                          }   
                          finally   
                          {   
                                  cnn.Close();   
                                  trans.Dispose();   
                                  cnn.Dispose();   
                          }   
                  }

3、SQl server中的事务例子

begin transaction
save transaction A

insert into demo values('BB','B term')
rollback TRANSACTION A

create table demo2(name varchar(10),age int)
insert into demo2(name,age) values('lis',1)
rollback transaction

  insert into demo values('BB','B term')

commit TRANSACTION A

commit TRANSACTION  

4、注意

  1。事务必须在连接打开后BeginTransaction();

  2.事务添加到SqlCommand(sqlCommand.Transaction   =   sqlTransaction;   )

  3、其他数据库对应做相应调整

  4、可以用微软提供的一个dll,很方便.





欢迎光临 黑马程序员技术交流社区 (http://bbs.itheima.com/) 黑马程序员IT技术论坛 X3.2