先说一下什么是事务:
事务是应用程序中一系列严密的操作,所有操作必须成功完成,否则在每个操作中所作的所有更改都会被撤消。也就是事务具有原子性,一个事务中的一系列的操作要么全部成功,要么一个都不做。事务的结束有两种,当事务中的所有步骤全部成功执行时,事务提交。如果其中一个步骤失败,将发生回滚操作,撤消事务开始时的所有操作。
事务的ACID
事务具有四个特征:原子性( Atomicity )、一致性( Consistency )、隔离性( Isolation )和持续性( Durability )。这四个特性简称为 ACID 特性。
1 、原子性。事务是数据库的逻辑工作单位,事务中包含的各操作要么都做,要么都不做。
2 、一致性。事务执行的结果必须是使数据库从一个一致性状态变到另一个一致性状态。因此当数据库只包含成功事务提交的结果时,就说数据库处于一致性状态。如果数据库系统运行中发生故障,有些事务尚未完成就被迫中断,这些未完成事务对数据库所做的修改有一部分已写入物理数据库,这时数据库就处于一种不正确的状态,或者说是不一致的状态。
3 、隔离性。一个事务的执行不能被其它事务干扰。即一个事务内部的操作及使用的数据对其它并发事务是隔离的,并发执行的各个事务之间不能互相干扰。
4 、持续性。也称永久性,指一个事务一旦提交,它对数据库中的数据的改变就应该是永久性的。接下来的其它操作或故障不应该对其执行结果有任何影响。
三种读异常(三种并发问题)
脏读Drity Read:读取了其他未提交的数据,但是未提交的事务进行了回滚。
不可重复读Non-repeatable read:事务1读取某数据,事务二进行了更新并提交,事务一再来读的时候数据已经被改变(更新)。
幻读Phantom Read:事务1读取某数据,事务二进行了新增并提交,事务1读,发现有新的数据出现。
事务的四种隔离级别
在数据库操作中,为了有效保证并发读取数据的正确性,提出的事务隔离级别。我们的数据库锁,也是为了构建这些隔离级别存在的。
低级别的隔离级一般支持更高的并发处理,并拥有更低的系统开销。
Read Uncommitted 读未提交(select不加锁):
all事务都能看到其他未提交事务的执行结果。安全性弱。
读取未提交的数据,被称之为脏读。
Read Committed 读已提交
(普通select快照读,锁select /update /delete 会使用记录锁,除了在外键约束检查(foreign-key constraint checking)以及重复键检查(duplicate-key checking)时会封锁区间)
除了Mysql之外的大多数数据库系统的默认隔离级别。一个事务只能看见已经提交事务所做的改变。解决了脏读的问题,但是依然有不可重复读的异常。
Repeatable Read可重复读:
普通select快照读,锁select /update /delete 根据查询条件情况,会选择记录锁,或者间隙锁/临键锁,以防止读取到幻影记录
mysql的默认隔离级别。保证了同一个事务的多个实例在并发读取数据的时候,会看到同样的数据行。解决了脏读和不可重复读的异常,存在幻读的异常。
InnoDB和Falcon、PBXT存储引擎通过MVCC(多版本并发控制)机制进行解决该问题。