java 事务 异常处理_两个service互相调用,抛出异常时的事务处理

问题描述

serviceA中的methodA调用serviceB中的methodB,methodB抛出一个异常,然后methodA捕获掉这个异常,就会出现

Transaction rolled back because it has been marked as rollback-only 异常

(serviceA和serviceB都加了注解@Transactional(rollbackFor = Exception.class))

问题出现的环境背景及自己尝试过哪些方法

业务需求是在serviceA中的methodA中调用serviceB中的methodB,但是methodB有一定几率会抛异常,methodA要把异常捕获,并做其他处理。

但是methodA返回结果的时候就会报“Transaction rolled back because it has been marked as rollback-only”异常。

解决办法是在methodB上添加注解@Transactional(rollbackFor = Exception.class, propagation = Propagation.REQUIRES_NEW)。还有一种办法是把methodB写到serviceA中,直接用this.methodB调用

疑惑

现在想搞明白为什么serviceA不能捕获serviceB中的异常?

serviceA中的methodA中调用serviceB中的methodB和同一个service中两个方法调用,在事务处理上有什么区别?

  • 0
    点赞
  • 3
    收藏
    觉得还不错? 一键收藏
  • 0
    评论
在 Spring Boot 中,事务处理非常简单,只需要添加注解即可。通常情况下,我们使用 @Transactional 注解来标记一个方法需要事务处理。 使用 @Transactional 注解,需要注意以下几点: 1. 在类或方法上添加 @Transactional 注解,表示该类或方法需要事务处理。 2. 在方法上添加 @Transactional 注解,默认情况下事务只在 RuntimeException 及其子类异常回滚。 3. 可以通过设置 rollbackFor 属性来指定需要回滚的异常类型。 4. 事务只在 public 方法上起作用。 5. 如果在一个类的方法中调用另一个方法,被调用的方法上的 @Transactional 注解不会起作用,需要在被调用的方法所在的类上添加 @Transactional 注解。 示例代码如下: ```java @Service public class UserService { @Autowired private UserDao userDao; @Transactional public void save(User user) { userDao.save(user); } @Transactional(propagation = Propagation.REQUIRED, rollbackFor = Exception.class) public void delete(Long id) throws Exception { User user = userDao.findById(id); if (user == null) { throw new Exception("用户不存在"); } userDao.delete(user); } } ``` 在上面的示例代码中,我们定义了两个方法:save 和 delete。在 save 方法上添加了 @Transactional 注解,表示该方法需要事务处理。在 delete 方法上,我们通过设置 propagation 属性来指定事务的传播行为,通过设置 rollbackFor 属性来指定需要回滚的异常类型。 需要注意的是,在使用事务处理,一定要保证事务的粒度要尽可能小,以减少事务的锁定间,提高并发性能。同,对于需要回滚的异常类型,一定要慎重选择,避免将不需要回滚的异常也加入回滚列表中,导致事务回滚过于频繁,影响性能。
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值