目录
在深入和使用spring事务之前,我们需要先知悉一些事务的基本概念。
事务的四大特性 | A(原子性)C(一致性)I(隔离性)D(持久性) |
事务存在的问题 | 脏读、幻读、不可重复读 |
事务的隔离级别 | 读未提交(READ UNCOMMITTED) 读已提交(READ COMMITTED) 可重复读(REPEATABLE READ) 串行化(SERIALIZABLE) |
事务的传播级别 |
|
本文不举太多复杂的例子,力求言简意赅,方便同志学习以及自查。
事务的四大特性
Atomic(原子性)Consistent(一致性)Isolation(隔离性)Durabilty(持久性)
- Atomic:事务中可能包含多个操作,但要么都完成,要么都失败。
- Consistent:事务前后数据完整性约束不被破坏(不懂,说明没啥卵用)
- Isolation:两个事务应该互不干扰(终极目标)
- Durability:事务一旦提交(完成),数据永久被修改
事务存在的问题
但在日常开发中,要求两个事务完全互不干扰是不可能的,你总要对数据库的吞吐量或业务本身做妥协,并选择合适自身业务场景的事务隔离级别,所以面临脏读、幻读、不可重复读是不可避免的。
定义 | 存在的问题 | |
脏读 | 事务A读到的数据是脏数据 | 情况1:事务A能读到事务B未提交的数据 情况2:事务A读不到事务B已提交的数据 前者事务B可能回滚; 后者事务A总在使用落后的数据; 这都是脏数据,是脏读。 |
不可重复 | 事务A读到且使用了事务B已提交的数据 | 若事务A先后两次读取数据,将读到不同的数据。 |
幻读 | 同不可重复 前者针对同一条数据 后者针对同一范围的数据 | 若事务A先后两次读取分数>60的人数,结果会不同。 |
而不同的事务隔离级别,面临的事务问题不同。
定义 | 存在的问题 | |
READ UNCOMMITTED | 事务A读到且使用了事务B未提交的数据 | 隔离级别最低 防不住:脏读、幻读、不可重复读 |
READ COMMITTED | 事务A读到且使用了事务B已提交的数据 | 日常开发常用级别 防不住:幻读、不可重复读 |
REPEATABLE READ | 事务A所使用的数据行,全程不变 | 会锁住数据行 防不住:幻读 毕竞你锁的只有一行,而幻读是AOE更新啊! |
SERIALIZABLE | 完全串行化 | 会锁表,吞吐量低 |
事务的传播级别
事务的传播级别是spring中常用的概念,因为spring事务控制的最细粒度为方法级别,但如果带有事务的方法A调用了事务方法B,这两个方法中的事务该怎么处理?
定义 | |
Required | 融为一个主线事务 |
Required New | 事务A中新启动一个事务B 并将事务A挂起 若事务B失败,则B回滚,A不回滚 |
Required Nested | 融为一体,但分主线支线 A为主线B为支线 支线失败不影响主线 |