事务回滚,同时记录异常信息

该博客介绍了在Java环境中如何在出现异常时回滚数据库操作并记录异常信息。通过开启新事务,利用HTTP异步请求保存异常详情,确保主程序抛出异常后仍能正确处理。在finally块中,使用`@Transactional`注解和`DataSourceTransactionManager`来控制事务,确保异常信息的插入不受影响。
摘要由CSDN通过智能技术生成

需求

在发生异常时,回滚对数据库的操作,同时在数据库中插入一条异常信息。

实现原理

开启新的事务,进行异常信息的数据库操作

实现

1、依赖HTTP重新发送请求

在抛出异常前,依赖http,发送一条异步请求,由一个接口保存异常信息,然后主程序再抛出异常。

2、开启新事务,插入异常信息

@Autowired
private DataSourceTransactionManager dstManager;

@Transactional
@Override
public void create(Payment payment) throws Exception {
    try {
        paymentDao.create(payment);
        System.out.println(1 / 0);
    } catch (Exception e) {
        TransactionAspectSupport.currentTransactionStatus().setRollbackOnly();
        //此处可添加抛出异常信息,不影响现有逻辑
    } finally {
        // 事物隔离级别,开启新事务,这样会比较安全些。
        DefaultTransactionDefinition def = new DefaultTransactionDefinition();
        def.setPropagationBehavior(TransactionDefinition.PROPAGATION_REQUIRES_NEW);
        // 获得事务状态
        TransactionStatus transaction = dstManager.getTransaction(def);
        try {
            payment.setSerial("报错啦啦啦啦啦啦");
            paymentDao.create(payment);
            dstManager.commit(transaction);
        } catch (Exception e) {
            dstManager.rollback(transaction);
            logger.error("临时表插入失败:" + e.getMessage(), e);
        }
    }
}

一种实现方式,与上面的代码思想是一样的

@Transactional
@Override
public void create(Payment payment) {
    paymentDao.create1(payment);
    paymentService.newTransCreate(payment);
    System.out.println(1 / 0);
}

@Override
@Transactional(propagation = Propagation.REQUIRES_NEW, rollbackFor = Exception.class)
public void newTransCreate(Payment payment) {
    payment.setSerial("这是一个新的报错信息");
    paymentDao.create2(payment);
}
  • 1
    点赞
  • 4
    收藏
    觉得还不错? 一键收藏
  • 4
    评论
评论 4
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值