事务基本信息

一、事务的定义

  事务(Transaction)是由一系列对系统数据进行访问与更新的操作所组成的一个程序执行逻辑单元(Unit),侠义上的事务特质数据库事务。1)当多个应用程序并发访问数据库时,事务可以在这些应用之间提供一个隔离方法,以防止彼此的操作互相干扰。2)事务为数据库操作序列提供了一个从失败中恢复到正常状态的方法,同时提供了数据库即使在异常状态下仍能保持数据一致性的方法。

二、事务的四个特征(ACID)

  分别是原子性(Atomicity),一致性(Consistency),隔离性(Isolation),持久性(Durability),简称ACID特性。

1)原子性

  事务的原子性是指事务必须是一个原子的操作序列单元。事务中包含的各项操作在一次执行过程中,只允许出现两种状态之一:①全部成功执行。②全部不执行。

  任何一项操作失败都将导致整个事务失败,同时其它已经被执行的操作都将被撤销并回滚,只有所有的操作全部成功,整个事务才算是成功完成。

2)一致性

  事务的一致性是指事务的执行不能破环数据库数据的完整性和一致性,一个事务在执行之前和执行之后,数据库都必须处于一致性状态。如果数据库系统在运行过程中发生故障,有些事务尚未完成就被迫中断,这些未完成的事务对数据库所做的修改有一部分已写入物理数据库,这时数据库就处于一种不正确的状态,或者说不一致的状态。

3)隔离性

  事务的隔离性是指在并发环境中,并发的事务是相互隔离的,一个事务的执行不能被其它事务干扰。也就是说,不同的事务并发操纵相同的数据时,每个事务都有各自完整的数据空间,即一个事务内部的操作及使用的数据对其它并发事务是隔离的,并发执行的各个事务之间不能互相干扰。

标准AQL规范中定义的4个事务隔离级别,不同的隔离级别对事务的处理不同

①未授权读取,也被称为读未提交,该隔离级别允许脏读取,其隔离级别最低。事务B可以看到事务A操作过程中的数据变化。

②授权读取,也被成为读已提交,只允许读取已经被提交的数据。

③可重复读取(Repeatable Read),就是保证在事务处理过程中,多次读取同一个数据时,其值都和事务开始时刻是一致的。

④串行化(Serializable)是最严格的事务隔离级别。要求所有事务都被串行化 执行

4)持久性

  事务的持久性是指一个事务一旦提交,它对数据库中对应数据的状态变更就应该是永久的。

幻读(幻影数据):指同样的事务操作,在前后两个时间段内执行对同一个数据项的读取,可能出现不一致的结果。

  事务隔离级别越高,就越能保证数据的完整性和一致性,但同时对并发性能的影响也就越大。通常,对于绝大多数的应用程序来说,可以优先考虑将数据库系统的隔离级别设置为授权读取,这能够在避免脏读的同时保证较好的并发性能。尽管这种事务隔离级别会导致不可重复读、虚读等并发问题,但较为科学的做法是在可能出现这类问题的个别场合中,有应用程序主动采用悲观锁或乐观锁来进行事务控制。

原文地址:https://www.cnblogs.com/TheoryDance/p/7499681.html