日期:2013-12-23  浏览次数:20468 次


关于事务的隔离性
例如:统计定单系统中事务活动 如下
1.事务T1打印定单表中的记录
2.T2向定单表插入了新的定单,T2提交
3.事务T1统计定单表中的的记录总数,T1提交
 由于事务T2在T1结束前向定单表中插入了新的记录,导致事务T1打印的定单记录数量和T1统计的定单数量不分歧.
  产生并发异常问题的次要缘由是并发操作破坏了事务的隔离性,导致数据不分歧.如何使一个事务不遭到其它事务的干扰,保证数据分歧性???
完整的例子代码,在线等待,谢谢大家的关怀:)


事务
事务是作为单个逻辑任务单元执行的一系列操作。一个逻辑任务单元必须有四个属性,称为 ACID(原子性、分歧性、隔离性和持久性)属性,只要这样才能成为一个事务:

原子性

事务必须是原子任务单元;对于其数据修正,要么全都执行,要么全都不执行。

分歧性

事务在完成时,必须使所有的数据都保持分歧形状。在相关数据库中,所有规则都必须使用于事务的修正,以保持所无数据的完整性。
事务结束时,所有的内部数据结构(如 B 树索引或双向链表)都必须是正确的。

 

隔离性

由并发事务所作的修正必须与任何其它并发事务所作的修正隔离。事务查看数据时数据所处的形状,要么是另一并发事务修正它之前的形状,
要么是另一事务修正它之后的形状,事务不会查看两头形状的数据。这称为可串行性,由于它能够重新装载起始数据,并且重播一系列事务,
以使数据结束时的形状与原始事务执行的形状相反。

持久性

事务完成之后,它对于系统的影响是永世性的。该修正即便出现系统毛病也将不断保持。

指定和强制事务处理
SQL 程序员要担任启动和结束事务,同时强制保持数据的逻辑分歧性。程序员必须定义数据修正的顺序,使数据绝对于其组织的业务规则保持
分歧。然后,程序员将这些修正语句包括到一个事务中,使 Microsoft® SQL Server™ 能够强制该事务的物理完整性。

企业数据库系统(如 SQL Server)有责任提供一种机制,保证每个事务物理的完整性。SQL Server 提供:

锁定设备,使事务互相隔离。


记录设备,保证事务的持久性。即便服务器硬件、操作系统或 SQL Server 本身出现毛病,SQL Server 也可以在重新启动时使用事务日志,
将所有未完成的事务自动地回滚到系统出现毛病的位置。


事务管理特性,强制保持事务的原子性和分歧性。事务启动之后,就必须成功完成,否则 SQL Server 将撤消该事务启动之后对数据所作的所有修正。