繁体   English   中英

JpaTransactionManager不回滚事务

[英]JpaTransactionManager doesn't rollback transaction

我使用JHipster制作一个简单的应用程序并编写服务,代码如下:

@Service
@Transactional
public class OperateQueueActionService {
    @Transactional(rollbackFor = Throwable.class)
    public OperateQueueDTO apply(OperateQueueDTO operateQueueDTO, QueueEventType queueEventType, String deskNo) {
    StateMachine<QueueStatus, QueueEventType> stateMachine = operateQueueActionMachineService.getStateMachine();
    try {   QueueEventDTO operateQueueEventDTO = operateQueueUtils.saveQueueEvent(operateQueueDTO, queueEventType, deskNo); 
         ......in process will throw RuntimeException.
        } finally {
           stateMachine.stop();
       }
    }
}

我希望事务回滚,而不要保存queueEvent ,但是记录将保存在数据库中。 这是事务日志:

[2018-07-24 12:04:51.861] [XNIO-2 task-6] WARN osslCompositeStateMachineListener -Error during stateContext java.lang.RuntimeException: 无效状态 at com.higoee.queue.state.utils.OperateQueueStateMachineLogListener.stateContext(OperateQueueStateMachineLogListener.java:58) at java.lang.Thread.run(Thread.java:745) [2018-07-24 12:04:51.871] [XNIO-2 task-6] INFO chqsuOperateQueueStateMachineLogListener -4d667539-3316-491d-a0db-240e29b0fcae状态机状态为:STATEMACHINE_STOP [2018-07-24 12:04:51.872] [XNIO-2 task-6] DEBUG osorm.jpa.JpaTransactionManager -Initiating transaction commit [2018-07-24 12:04:51.874] [XNIO-2 task-6] DEBUG osorm.jpa.JpaTransactionManager -Committing JPA transaction on EntityManager

JPA配置没有问题,弹簧状态机已捕获到StateMachineListenerAdapter中引发的异常。

暂无
暂无

声明:本站的技术帖子网页,遵循CC BY-SA 4.0协议,如果您需要转载,请注明本站网址或者原文地址。任何问题请咨询:yoyou2525@163.com.

 
粤ICP备18138465号  © 2020-2024 STACKOOM.COM