七、事务管理
事务 是一组操作的集合,它是一个不可分割的工作单位,这些操作要么同时成功、要么同时失败。
- 操作:
- 开启事务:start transaction/begin
- 提交事务:commit
- 回滚事务:rollback
此时删除部门的话,部门数据可以删去,但是员工数据并没有删去,造成了数据的不一致。因为在int i = 1/0那里出现了异常,程序停止。解决办法是让这三行代码处于一个事务当中。
7.1 Spring事务管理
/*
注解:@Transactional
位置:业务层(service)的方法上、类上、接口上
作用:将当前方法交给spring进行事务管理,方法执行前开启事务;成功执行完毕提交事务;出现异常回滚事务
*/
7.2 Spring事务管理日志
#spring事务管理日志,每次启动SpringBoot时,会记录事务的执行情况
logging:
level:
org.springframework.jdbc.support.JdbcTransactionManager: debug
7.3 事务进阶
@Transactional(rollbackFor = Exception.class)
/*
默认情况下,只有出现RuntimeException或者Error才回滚异常。rollbackFor属性用于控制出现何种异常类型,回滚事务。如果在没有设置该属性的情况下执行下面的程序,那么就会跟上面一样,部门数据删除了而部门下的员工数据没有删除,造成数据不一致。
*/
/*
propagation
事务传播行为:指的就是当一个事务方法被另一个事务方法调用时,这个事务方法应该如何进行事务控制。
我们可以在propagation中添加属性值
*/
@Transactional(propagation = Propagation.REQUIRED)
属性值 | 含义 |
---|---|
REQUIRED | 默认值。支持当前事务,如果当前没有事务,就新建一个事务 |
REQUIRED_NEW | 新建事务,如果当前存在事务,就把当前事务挂起 |
SUPPORTS | 支持当前事务,如果当前没有事务,就以非事务方式执行 |
NOT_SUPPORTED | 以非事务方式执行操作,如果当前存在事务,就把当前事务挂起 |
MANDATORY | 支持当前事务,如果当前没有事务,就抛出异常 |
NEVER | 以非事务方式执行,如果当前存在事务,则抛出异常 |
NESTED | 如果当前存在事务,则嵌套事务内执行。如果当前没有事务,则进行与REQUIRED类似的操作 |
我们主要关注REQUIRED跟REQUIRED_NEW
- REQUIRED:大部分情况下都是用该传播行为即可
- REQUIRED_NEW:当我们不希望事务之间相互影响时,可以使用该传播行为。比如:下订单前需要记录日志,不论订单保存成功与否,都需要保证日志记录都能够记录成功。
其中,以非事务方式运行,表示以非Spring事务运行,表示在执行这个方法时,Spring事务管理器不会去建立数据库连接。执行sql时,由Mybatis或JDBC Template自己来建立数据库来执行sql。