gpt4 book ai didi

Spring + Hibernate 如何防止回滚

转载 作者:行者123 更新时间:2023-12-02 05:48:02 24 4
gpt4 key购买 nike

我有一个使用此方法的代码块:

@Transactional(noRollbackFor=Exception.class)
public synchronized Object saveData(){
//...
dao.insert(entity);
//...
}

我的 dao 类被标记为 ad Transactional

@Transactional
public class Dao {
//...
public <T> void insert(T obj) throws Exception {
getSession().saveOrUpdate(obj);
}
}

我需要防止该 block 内发生任何回滚。但是我得到了这个:

2014-02-25 20:47:44 [WARN]SqlExceptionHelper:143    SQL Error: 1205, SQLState: 41000
2014-02-25 20:47:44 [ERROR]SqlExceptionHelper:144 Lock wait timeout exceeded; try restarting transaction
2014-02-25 20:47:44 [ERROR]BigliettiService:? Transazione in errore
org.hibernate.exception.GenericJDBCException: Lock wait timeout exceeded; try restarting transaction
...
2014-02-25 20:47:44 [ERROR]JsonHandlerExceptionResolver:? Transaction rolled back because it has been marked as rollback-only

为什么最后我发现事务回滚了?

最佳答案

上周我也遇到了类似的问题。就我而言,是来自不同方法的另一个 @Transactional 注释导致事务被标记为仅回滚。

你检查过了吗?

编辑:为了更清楚地说明这一点,您没有从 saveData() 方法内部发布代码。对我来说导致此错误的原因是从我的方法内部使用 @Transactional (缺少 noRollback 属性)调用另一个方法,在您的情况下是 saveData()

关于Spring + Hibernate 如何防止回滚,我们在Stack Overflow上找到一个类似的问题: https://stackoverflow.com/questions/22071282/

24 4 0
Copyright 2021 - 2024 cfsdn All Rights Reserved 蜀ICP备2022000587号
广告合作:1813099741@qq.com 6ren.com