事务回滚,同时记录异常信息
Posted root_zhb
tags:
篇首语:本文由小常识网(cha138.com)小编为大家整理,主要介绍了事务回滚,同时记录异常信息相关的知识,希望对你有一定的参考价值。
事务回滚,同时记录异常信息
需求
在发生异常时,回滚对数据库的操作,同时在数据库中插入一条异常信息。
实现原理
开启新的事务,进行异常信息的数据库操作
实现
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.create(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.create(payment);
以上是关于事务回滚,同时记录异常信息的主要内容,如果未能解决你的问题,请参考以下文章