事务的ACID特性
atomicity: 原子性: 一个事务要么全部提交成功, 要么全部失败回滚。
consistency: 一致性:事务的执行不能破坏数据库数据的完整性和一致性,一个事务在执行之前和执行之后,数据库都必须处于一致性状态。
isolation:隔离性: 在并发环境下, 事务是相互隔离的, 互不影响。
durability:持久性:事务的作用是持久的, 一旦事务提交, 就永远保存。
关于隔离性, 数据库的4个隔离级别:
读未提交(Read Uncommited):脏读。
已提交读(Read Commited): 不可重复读。
可重复读(Repeatable Read): 幻读。
串行化:是最严格的事务隔离级别,它要求所有事务被串行执行,即事务只能一个接一个的进行处理,不能并发执行。
Spring事务的配置方式
spring 事务的实现方式有两种: (1)声明式 (2) 编程式
编程式: 可以基于API也可以基于TransactionTemplate , 通过编码实现。
声明式: 可以直接用@Transactional 注解实现。
事务的传播机制
什么是事务的传播: 假如 一个事务A里面调用了事务B, 那么是他们两个分别提交, 还是合并成一个提交。这就是事务的传播.
-
PROPAGATION_REQUIRED
Spring默认的传播机制,能满足绝大部分业务需求,如果外层有事务,则当前事务加入到外层事务,一块提交,一块回滚。如果外层没有事务,新建一个事务执行 -
PROPAGATION_REQUES_NEW
该事务传播机制是每次都会新开启一个事务,同时把外层事务挂起,当当前事务执行完毕,恢复上层事务的执行。如果外层没有事务,执行当前新开启的事务即可 -
PROPAGATION_SUPPORT 如果外层有事务,则加入外层事务,如果外层没有事务,则直接使用非事务方式执行。完全依赖外层的事务
-
PROPAGATION_NOT_SUPPORT
该传播机制不支持事务,如果外层存在事务则挂起,执行完当前代码,则恢复外层事务,无论是否异常都不会回滚当前的代码 -
PROPAGATION_NEVER 该传播机制不支持外层事务,即如果外层有事务就抛出异常 PROPAGATION_MANDATORY
与NEVER相反,如果外层没有事务,则抛出异常 -
PROPAGATION_NESTED
该传播机制的特点是可以保存状态保存点,当前事务回滚到某一个点,从而避免所有的嵌套事务都回滚,即各自回滚各自的,如果子事务没有把异常吃掉,基本还是会引起全部回滚的。