在日常工作中,需要将接口通过try-catch将错误记录下来,保存到数据库,但是因为事务需要回滚,只能手动回滚,但是插入数据库操作也会回滚了。而新启事务(REQUIRD-NEW)。TransactionAspectSupport.currentTransactionStatus().setRollbackOnly();导致事务无法正常PROPAGATION_REQUIRES_NEW,所以需要手动提交。
@Resource(name="transactionManager") //项目内配置的事务manager
private DataSourceTransactionManager transactionManager;
DefaultTransactionDefinition transDefinition = new DefaultTransactionDefinition();
//开启新事物 transDefinition.setPropagationBehavior(DefaultTransactionDefinition.PROPAGATION_REQUIRES_NEW);
TransactionStatus transStatus = transactionManager.getTransaction(transDefinition);
transactionManager.commit(transStatus);
这篇博客探讨了在Java中处理数据库事务的问题,特别是在需要捕获异常并记录错误信息到数据库时,如何在回滚事务的同时确保错误日志的插入不受影响。作者提到了使用PROPAGATION_REQUIRES_NEW事务隔离级别遇到的挑战,并展示了如何通过手动控制事务来实现这一目标,包括开启新事务、设置回滚状态以及手动提交。
787

被折叠的 条评论
为什么被折叠?



