spring-boot 事务配置

1.首先确认对应数据库已开启事务支持,比如我用的mysql,执行SHOW VARIABLES LIKE '%xa%' 语句,如果看见 innodb_support_xa 的值为ON 表示已开启事务支持

2.确认你工程中用到的数据源连接配置方式,比如我系统中用到的是单数据源,就用的配置文件形式的druid的jdbc方式,

以上很重要,如果你是多数据源,那你就需要引用支持多数据源事务支持的jar包,如JTA。

3.工程pom中添加

<dependency>
   <groupId>org.springframework.boot</groupId>
   <artifactId>spring-boot-starter-jdbc</artifactId>
</dependency>

4.工程启动类中开启事务管理,添加:

@EnableTransactionManagement

5.根据业务范围在业务类中添加

@Transactional注解,我这用到的都是默认配置,对应事务的回滚触发条件是捕获到运行时异常,当然你如果想范围更广点,可以手动配置触发条件,如:@Transactional(rollbackFor = Exception.class) 

注意几点:事务注解只对public类或方法有效,不要在添加事务控制的方法中加入try catch捕获异常,一旦捕获就无法自动完成回滚,如果添加了异常捕获,在catch中加入

TransactionAspectSupport.currentTransactionStatus().setRollbackOnly(),进行手动回滚

以上只是个简单的参考,具体操作还是要根据业务来定。

评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值