@Transactional(rollbackFor = Exception.class) 是 @Transactional 注解的一个参数,它指定了事务回滚的条件,即在出现指定的异常时触发回滚操作。
在默认情况下,@Transactional 注解只有在出现 RuntimeException 或者 Error 异常时才会回滚事务。而通过 rollbackFor 属性可以自己指定期望回滚的异常类型。
rollbackFor = Exception.class 表示回滚事务的条件是出现任何 Exception 异常或者其子类时都需要进行事务回滚。可以使用 rollbackFor = Throwable.class 来回滚所有的异常,包括 Error,不过这种操作不推荐,因为回滚 Error 会导致整个应用挂掉。
下面是一个简单的示例,展示了如何使用 @Transactional 注解和 rollbackFor 属性:
@Service
public class UserServiceImpl implements UserService {
private final UserDao userDao;
@Autowired
public UserServiceImpl(UserDao userDao) {
this.userDao = userDao;
}
// 添加 @Transactional 注解,并指定回滚条件
@Override
@Transactional(rollbackFor = Exception.class)
public void transferAmount(String fromUser, String toUser, double amount) throws Exception {
// 将 fromUser 的钱转到 toUser 的账户
userDao.updateBalance(fromUser, -amount);
userDao.updateBalance(toUser, amount);
// 制造一个异常,测试事务是否回滚
throw new Exception("手动抛出一个异常,测试事务回滚");
}
}
在上面的示例中,UserService.transferAmount 方法被添加了 @Transactional 注解,并指定了回滚条件为出现任何 Exception 类型的异常时都需要回滚事务。当方法中执行到手动抛出异常的代码时,事务会被回滚,因此用户的余额也不会发生变化。通过这种方式,我们可以保证转账操作不会因为异常而导致数据的破坏。