0

在我的 Spring 应用程序中,我将服务层方法标记为@Transactional(propagation=Propagation.REQUIRED)并且正在使用<tx:annotation-driven />. 通常,当方法完成时自动提交事务的默认行为就像一个魅力。但在特定情况下,我需要在方法结束前不久提交 - 是的,即使在那之后的部分抛出异常。

在这种方法中是否有办法访问当前事务?我试过这个:

TransactionDefinition td = new DefaultTransactionDefinition(TransactionDefinition.PROPAGATION_MANDATORY); // make sure we're talking about the same transaction already provided by the annotation
TransactionStatus status = transactionManager.getTransaction(td);

// perform various JDBC operations

transactionManager.commit(status);
methodThatNeedsToBeCalledAfterCommit();

但是查看我的日志,我只看到“AbstractPlatformTransactionManager.processCommit(752) | 启动事务提交”发生一次,并且从时间戳来看,这似乎是after methodThatNeedsToBeCalledAfterCommit(),这将是@Transactional方法的正常行为。

有没有办法在这种方法中实际强制提交?

4

3 回答 3

1

我不这么认为。此外,Spring 将尝试在您的方法结束时重新提交。所以 2 次提交:不好。

你应该重新考虑你的方法的组织。也许将现有的一种方法分成 2 种方法:一种使用 @Trnasactional,另一种使用剩余的行。

于 2012-07-27T15:27:40.023 回答
0

这可能是因为默认的事务传播是 PROPAGATION_REQUIRED,因此只有在整个事务完成时才会提交 - 这是您的外部方法。您可以尝试使用 PROPAGATION_REQUIRES_NEW:

td.setPropagationBehavior(TransactionDefinition.PROPAGATION_REQUIRED);

另一种选择是使用TransactionTemplate

于 2012-07-27T17:25:59.180 回答
0

尝试从要应用事务的程序中调用此方法。

     DefaultTransactionDefinition transdefinition = new DefaultTransactionDefinition();
         PlatformTransactionManager manager =new  PlatformTransactionManager(); 
         TransactionStatus status=null;




public void beginTransaction()
    {

        transdefinition.setPropagationBehavior(0); 


         status = manager.getTransaction(transdefinition);
    }

public void commitTransaction()
    {
if(status.isCompleted()){
manager.commit(status);
    }
}

 public void rollbackTransaction()
    {
if(!status.isCompleted()){
       manager.rollback(status);  
    }
}
于 2013-04-08T03:55:30.073 回答