单机数据库下的ACID
事务是由一系列对系统中数据进行访问与更新的操作所组成的一个程序执行逻辑单元,狭义上的事务特指数据库事务。事务具有四个特征,分别是原子性(Atomicity)、一致性(Consistency)、隔离性(Isolation)和持久性(Durability),简称为事务的ACID特性。
1.原子性
原子性指事务必须是一个原子的操作序列单元。事务中包含的各项操作在一次执行过程中,要么全部执行成功,要么全部不执行。任何一项操作失败都将导致整个事务失败。
2.一致性
一致性是指事务的执行不能破坏数据库数据的完整性和一致性。事务执行的结果必须是使数据库从一个一致性状态转变到另一个一致性状态,如果数据库系统在运行过程中发生故障,有些事务还没有完成就被迫中断,这时数据库就是不一致的状态,是不正确的状态。
3.隔离性
隔离性是指在并发环境中,并发的事务是相互隔离的,一个事务的执行不能被其他事务干扰。不同的事务并发操纵数据时,每个事务都有各自完整的数据空间,一个事务内部的操作即使用的数据对其他事务是隔离的,并发执行的各个事务之间不能相互干扰。
在标准SQL规范中,定义了4个隔离级别,不同的隔离级别对事务的处理不同。
(1)未授权读取
未授权读取也被称为读未提交,该隔离级别允许脏读,为级别最低的隔离级别。如果一个事务正在处理某一数据,并对其进行了更新,但同时尚未完成事务,还没有进行事务提交;而与此同时,允许另一个事务也能够访问该数据。如下图所示。
(2)授权读取
授权读取也被称为读已提交,它和未授权读取非常接近,唯一的区别就是授权读取只允许获取已经被提交的数据。授权读取允许不可重复读取。
(3)可重复读取
可重复读取就是保证在事务处理过程中,多次读取同一个数据时,其值都和事务开始时刻是一致的。该事务级别禁止了不可重复读取和脏读,但是可能出现幻影数据。
幻影数据就是指同样的事务操作,在前后两个时间段内执行同一个数据项的读取,可能出现不一致的结果。
(4)串行化
串行化是最严格的事务隔离级别,它要求所有事务都被串行化执行,也就是事务只能一个接一个地处理,不能并发执行。
下图展示了不同隔离级别下事务访问数据的差异:
以上四个隔离级别的隔离性依次增强,分别解决不同的问题,下表对其进行一个简单对比。
事务隔离级别越高,越能保证数据的完整性和一致性,但是同时对并发性能的影响也越大。通常对于大多数的应用程序来说,可以优先考虑将数据库的隔离级别设置为授权读取,这样可以在避免脏读的同时保证较好的并发性能。
4.持久性
持久性也被称为永久性,指一个事务一旦提交,它对数据库中对应数据的状态变更就应该是永久性的。也就是说,一旦某个事务成功结束,那么它对数据库所做的更新就必须永久保存下来。