使用TransactionTemplate进行数据库回滚时,怎样保存错误日志

业务场景:

将一堆数据插入数据库的时候,可能会有报错,统计完全部的数据都有什么报错之后,要将已经插入的数据回滚,

并且在错误日志中记录全部数据中都有什么数据发生了错误

代码:

  public void insertAndLog(){
        List<JSONObject> errorLogInfoList=new ArrayList<>();
        
        new TransactionTemplate().execute(new TransactionCallback<Object>() {
            @Override
            public Object doInTransaction(TransactionStatus transactionStatus) {
                //(1)生成保存点
                Object savepoint = transactionStatus.createSavepoint();
                //(2)todo 遍历数据,插入数据库,返回结果为错误日志,将错误日志放进集合errorLogInfoList中
                //*********执行主要业务,过程中出现错误则回滚,并返回错误日志*************
                
                //(3)异常个数大于0,则回滚,待记录完错误日志再抛出异常,否则(4)执行不到
                if (errorLogInfoList.size() > 0) {
                    //回滚
                    transactionStatus.rollbackToSavepoint(savepoint);
                    return null;
                }
                return null;
            }
        });
        
        //(4)todo 如果有错误日志,遍历错误日志集合errorLogInfoList,插入数据库,随后根据需要决定是否抛出异常
        //*********将错误日志插入数据库*************
        
    }

过程中遇到的问题:

之前以为把(4)的部分直接放在  transactionStatus.rollbackToSavepoint(savepoint); 后面就可以了,但是发现错误日志没有保存进去,也跟着回滚了

不太理解,回滚之后再保存的数据应该能保存进去的,难道是因为没有commit?但是没有找到对应的commit的方法

 

评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值