spring事务管理

事务的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
    该传播机制的特点是可以保存状态保存点,当前事务回滚到某一个点,从而避免所有的嵌套事务都回滚,即各自回滚各自的,如果子事务没有把异常吃掉,基本还是会引起全部回滚的。

评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值