Kevin-moon

学习在于分享
  博客园  :: 首页  :: 新随笔  :: 联系 :: 订阅 订阅  :: 管理

NET 事务分析-1(初步概念)

Posted on 2008-05-14 23:48  Kevin-moon  阅读(1911)  评论(4编辑  收藏  举报

最新一直在了解有关事务的内容, 所以想逐步进行下这阶段的总结.这是第一次写博,表达可能不怎么好,呵呵...

1、事务概念:
    将多个任务绑定在一起,具有ACID属性(原子、一致、隔离和持久性)。
2、事务类型:
 1、本地事务: 限制一个数据源,由System.Transaction提供的事务管理器管理
 2、分布式事务: 跨越多个资源,由驻留在各系统的Miscosoft分布式事务协调器协调

3、事务隔离级别:
    
脏读:当一个事务正在访问数据,并且对数据进行了修改,但是这个事务还没有提交。同时另外一个也在访问这数据,并且读取了已经修改的数据。这种依赖脏数据的操作可能不正确。
    
 不可重复读:在一个事务内,多次读取数据。在这个事务还没有结束的时候,另外一个事务修改了这个数据,如果修改的事务发生在第一个事务多次读取数据之间,就造成了一个事务内读取的数据不一样。
    
幻读:两个事务同时进行修改的时候,可能造成修改错误的现象。例如,A事务对用户表的NAME列进行统一修改,但同时B事务又进行了新增动作,这样就造成了A事务提交后有遗漏的数据。
    
IsolationLevel枚举:
        Serializable:最高隔离级别,事务期间可以读取可变数据,但是不能修改和新增数据。
        ReadUncommited: 无任何保护
        ReadCommited: 不可读取,可以修改数据
        Snapshot: 快照,可以读取可变数据。在事务修改数据之前,它验证在它最初读取数据之后另一个事务是否更改过这些数据。如果数据已被更新,则会引发错误。这样使事务可获取先前提交的数据值。 
        RepeatableRead: 可以读取,新增数据,但是不能修改数据

4NET提供的事务编程
    System.Transaction名称空间包含各种事务处理的类和实现方式
    1、使用事务范围实现隐式事务
        
TransactionScope:提供一个简单方法,通过这一方法,您不必与事务本身交互
        
using(TransactionScope scope = new TransactionScope())
        
 {
            
 /* Perform transactional work here */
            
scope.Complete();
         
}
        
可以设定的条件:
        
 ATransactionScopeOption枚举:事务范围
                
Requried: 加入事务范围
                   
RequriesNew: 开始一个新的事务
                   
Suppress: 不参与事务
               BTransactionScope超时
        
CTransactionScope隔离级别
    
2、使用可提交事务实现显式事务
            
主要的类:
            
CommittableTransaction:提供事务的显式实现方法,支持多个线程使用同一个事务的应用程序。            
                 Transaction:事务的基类
            
DependentTransaction:事务的克隆
                
DependentTransactionOption: 依赖事务的种类
                    
BlockCommitUntilComplete:依赖事务阻塞事务的提交过程,直至父事务超时或Complete 被调用
                    
RollbackIfNotComplete:如果在调用 Complete 之前在父事务上调用了“提交”,则依赖事务将自动中止该事务。 
            
案例:
        
显式事务的基本用法
        
//实例化事务
        
tx = new CommittableTransaction();
         
try
         
{
            
SqlConnection myConnection = new SqlConnection("");
            SqlCommand myCommand = new SqlCommand();
            myConnection.Open();
             //注册环境事务
            myConnection.EnlistTransaction(tx);
            myCommand.Connection = myConnection;
            myCommand.CommandText = "";
            myCommand.ExecuteNonQuery();
                    //提交事务
            tx.Commit();
          }
          Catch(Exception err)
          {
                    //事务回滚
             tx.Rollback();
           }
           Finally
           {
             myConnection.Close();
             tx = null;
           
}