Spring事务传播机制
什么是事务?
- 什么是事务
- 事务:逻辑上是多个写sql组成的操作,组成这组操作的各个单元,要么全部成功,要么全部失败.
- 事物的特性
- 原子性:事务不可分割
- 一致性:事务执行前后数据完整性保持一致
- 隔离性:一个事务的执行不应该受到其他事物的影响
- 持久性:一旦事务结束,数据就持久化到数据库
mysql的隔离级别
Read uncommitted
:读未提交,任何问题解决不了Read committed
:读已提交,解决脏读,但是不可重复度和幻读有可能发生(Oracle默认)Repeatable read
:重复度,解决脏读和不可重复读,但是幻读可能发生(msyql默认)Serializable
:序列化,解决所有读问题
在各个级别下会出现的问题
隔离级别 | 问题解释 | 常用语 |
---|---|---|
读未提交 | A事务读取到B事务未提交的数据 | 脏读 |
读已提交 | A事务使用同样的查询语句单结果集不通(数据内容) | 不可重复度 |
重复读(默认) | A事务使用同样的查询语句但返回的结果集数量不同(数据数量) | 幻读 |
串行化 | 没有数据问题(行锁+简希锁解决) |
事务失效的十种情况
- 使用java的
private
修饰符修饰的方法 - 使用
try-catch
捕获异常 - 使用j
PROPAGATION_NOT_SUPPORTED
以事务的方式提交 - 使用新的
线程
执行方法,导致事务绑定失败 - 使用
rollbackFor = RuntimeException.class
设置了回滚异常的类型,但抛出了Exception.class
从而导致失效 - 数据库引擎不支持事务
- 没有启用事务管理器
@EnableTransactionManagement
- 没有开启事务注解
@Transactional
- 在静态方法上开起
@Transactional
- 没有将事务交给
Spring
管理,或者使用new
初始化service对象
事务的7中传播机制
PROPAGATION_REQUIRED:
默认值,如果A中有事务,使用A中的事务,如果A没有,创建一个新的事务,将操作包含进来PROPAGATION_SUPPORTS :
支持事务,如果A中有事务,使用A中的事务。如果A没有事务,不使用事务。PROPAGATION_MANDATORY :
如果A中有事务,使用A中的事务。如果A没有事务,抛出异常。PROPAGATION_REQUIRES_NEW :
如果A中有事务,将A的事务挂起(暂停),创建新事务,只包含自身操作。如果A中没有事务,创建一个新事务,包含自身操作。PROPAGATION_NOT_SUPPORTED :
如果A中有事务,将A的事务挂起。不使用事务管理。PROPAGATION_NEVER :
如果A中有事务,报异常。PROPAGATION_NESTED :
嵌套事务,如果A中有事务,按照A的事务执行,执行完成后,设置一个保存点,执行B中的操作,如果没有异常,执行通过,如果有异常,可以选择回滚到最初始位置,也可以回滚到保存点。