Skip to content

事务管理

作者:唐亚峰 | battcn
字数统计:847 字

注意

事务注解只能应用到公共可见度的方法上,可以被应用于接口定义和接口方法,方法会覆盖类上面声明的事务。

如果使用数据源隔离或者多数据源请用 @DSTransactional 反之用 @Transactional 或者 @DSTransactional 都可以

案例讲解

例如用户新增需要插入用户表、用户与角色关联表,如果插入成功,那么一起成功,如果中间有一条出现异常,那么回滚之前的所有操作。

为了防止出现脏数据,就需要借助 Spring 事务管理器来让它实现回退。

单一数据源

注意

JDBC 链接不能用 spring.datasource.dynamic 方式,否则事务容易失效 得用 spring.datasource.jdbc 自带配置方式

java
@Transactional 
public void add(User user){
	// 新增用户信息
	userMapper.insert(user);
	// 新增用户与角色管理
	roleMapper.insert(role);
}

动态数据源

注意

动态数据源或者多数据必须用它,不然事务不会生效

java
@DSTransactional
public void add(User user){
	// 新增用户信息
	userMapper.insert(user);
	// 新增用户与角色管理
	roleMapper.insert(role);
}

事务特性

更多事务的内容可以自行 Google 或者看 Spring 官方文档

属性说明
propagation事务的传播行为,默认值为 REQUIRED。
isolation事务的隔离度,默认值采用 DEFAULT
timeout事务的超时时间,默认值为-1,不超时。如果设置了超时时间(单位秒),那么如果超过该时间限制了但事务还没有完成,则自动回滚事务。
read-only指定事务是否为只读事务,默认值为 false;为了忽略那些不需要事务的方法,比如读取数据,可以设置 read-only 为 true。
rollbackFor用于指定能够触发事务回滚的异常类型,如果有多个异常类型需要指定,各类型之间可以通过逗号分隔。
noRollbackFor抛出 no-rollback-for 指定的异常类型,不回滚事务。

提示

事务的传播机制是指如果在开始当前事务之前,一个事务上下文已经存在,此时有若干选项可以指定一个事务性方法的执行行为。 即:在执行一个@Transactinal注解标注的方法时,开启了事务;当该方法还在执行中时,另一个人也触发了该方法;那么此时怎么算事务呢,这时就可以通过事务的传播机制来指定处理方式。

TransactionDefinition传播行为的常量:

常量含义
TransactionDefinition.PROPAGATION_REQUIRED事务的传播行为,默认值为 REQUIRED。
TransactionDefinition.PROPAGATION_REQUIRES_NEW事务的隔离度,默认值采用 DEFAULT
TransactionDefinition.PROPAGATION_SUPPORTS事务的超时时间,默认值为-1,不超时。如果设置了超时时间(单位秒),那么如果超过该时间限制了但事务还没有完成,则自动回滚事务。
TransactionDefinition.PROPAGATION_NOT_SUPPORTED指定事务是否为只读事务,默认值为 false;为了忽略那些不需要事务的方法,比如读取数据,可以设置 read-only 为 true。
TransactionDefinition.PROPAGATION_NEVER用于指定能够触发事务回滚的异常类型,如果有多个异常类型需要指定,各类型之间可以通过逗号分隔。
TransactionDefinition.PROPAGATION_MANDATORY抛出 no-rollback-for 指定的异常类型,不回滚事务。
TransactionDefinition.PROPAGATION_NESTED抛出 no-rollback-for 指定的异常类型,不回滚事务。