最新一直在了解有关事务的内容, 所以想逐步进行下这阶段的总结.这是第一次写博,表达可能不怎么好,呵呵...
1、事务概念:
将多个任务绑定在一起,具有ACID属性(原子、一致、隔离和持久性)。
2、事务类型:
1、本地事务: 限制一个数据源,由System.Transaction提供的事务管理器管理
2、分布式事务: 跨越多个资源,由驻留在各系统的Miscosoft分布式事务协调器协调
3、事务隔离级别:
脏读:当一个事务正在访问数据,并且对数据进行了修改,但是这个事务还没有提交。同时另外一个也在访问这数据,并且读取了已经修改的数据。这种依赖脏数据的操作可能不正确。
不可重复读:在一个事务内,多次读取数据。在这个事务还没有结束的时候,另外一个事务修改了这个数据,如果修改的事务发生在第一个事务多次读取数据之间,就造成了一个事务内读取的数据不一样。
幻读:两个事务同时进行修改的时候,可能造成修改错误的现象。例如,A事务对用户表的NAME列进行统一修改,但同时B事务又进行了新增动作,这样就造成了A事务提交后有遗漏的数据。
IsolationLevel枚举:
Serializable:最高隔离级别,事务期间可以读取可变数据,但是不能修改和新增数据。
ReadUncommited: 无任何保护
ReadCommited: 不可读取,可以修改数据
Snapshot: 快照,可以读取可变数据。在事务修改数据之前,它验证在它最初读取数据之后另一个事务是否更改过这些数据。如果数据已被更新,则会引发错误。这样使事务可获取先前提交的数据值。
RepeatableRead: 可以读取,新增数据,但是不能修改数据
4、NET提供的事务编程
System.Transaction名称空间包含各种事务处理的类和实现方式
1、使用事务范围实现隐式事务
TransactionScope:提供一个简单方法,通过这一方法,您不必与事务本身交互
using(TransactionScope scope = new TransactionScope())
{
/* Perform transactional work here */
scope.Complete();
}
可以设定的条件:
A、TransactionScopeOption枚举:事务范围
Requried: 加入事务范围
RequriesNew: 开始一个新的事务
Suppress: 不参与事务
B、TransactionScope超时
C、TransactionScope隔离级别
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;
}