首页
学习
活动
专区
圈层
工具
发布
社区首页 >问答首页 >@ transactions标记为rollback时,只在@transactions用于子事务时才标记为回滚

@ transactions标记为rollback时,只在@transactions用于子事务时才标记为回滚
EN

Stack Overflow用户
提问于 2021-07-27 10:17:08
回答 1查看 748关注 0票数 0

我有一个类,该类的方法标记为@Transactional。在该方法中,标记为@Transactional的多个方法被调用。因此,在层次结构上,这就像有一个具有多个子事务的父事务。问题发生在我调用从DB获取数据的方法时,最后调用一个应该将数据存储在DB中的方法,然后事务提交失败并用"... transaction marked as rollback only ...“标记事务。

代码示例:

A类

代码语言:javascript
复制
class A{
    @Transactional
    public void parentMethod(){
        B b = B.getB();
        C c = c.getC();
        D d = new D();
        d.setB(b);
        d.setC(c);
        service.save(d);
    }
}

B类

代码语言:javascript
复制
class B{
    @Transactional
    public B getB(){
        repository.getById(xxx);
    }
}

C类

代码语言:javascript
复制
class C{
    @Transactional
    public C getC(){
        repository.getById(xxx);
    }
}

服务

代码语言:javascript
复制
@Transactional
public D save(D d){
    repository.save(d);
}

正如您在上面的代码中所看到的,当我调用方法service.save(d);时,我会得到"... transaction marked as rollback only ...“异常。但是,如果我像这样注释所有"get“子事务

代码语言:javascript
复制
 @Transactional(readOnly = true, propagation = Propagation.REQUIRES_NEW)

我得到了预期的结果,例如事务是正确提交的,没有例外情况发生。

注意:在我的实际示例中,在最终的"save();“方法之前,我有多个”保存();“方法和多个"get();”方法。

编辑:看看这个问题:Why get data and insert data from/in the DB is not working within the same 'parent' transaction?

这和这个问题有关。但这个问题仍然存在。

EN

回答 1

Stack Overflow用户

发布于 2021-07-27 10:33:39

Propagation.REQUIRES_NEW:不要使用它,因为它创建了一个新事务,如果存在当前事务,则挂起当前事务。

使用默认配置@ transaction:Propagation.REQUIRED支持当前事务,如果不存在,则创建新事务。

票数 0
EN
页面原文内容由Stack Overflow提供。腾讯云小微IT领域专用引擎提供翻译支持
原文链接:

https://stackoverflow.com/questions/68543082

复制
相关文章

相似问题

领券
问题归档专栏文章快讯文章归档关键词归档开发者手册归档开发者手册 Section 归档