jiobanma
V2EX  ›  Java

关于 springboot+mybatis 的事务管理问题

  •  
  •   jiobanma ·
    banmajio · Sep 15, 2020 · 2719 views
    This topic created in 2078 days ago, the information mentioned may be changed or developed.

    对事务不熟悉一直没有用过,所以问题可能会比较 rz !! 如果我在一个 controller 中有一个方法,要去删除数据流程是:先调用关联表的 service 去删除关联变的数据, 然后再去调用主表的 service 删除主表的数据。这两个删除方法存在于不同的 service 接口中。这个时候我该如何做到在这个流程中如果某一个删除出现问题,让该流程中改变的数据进行回滚?(在不改变 service 结构的情况下)

    Supplement 1  ·  Sep 15, 2020
    https://blog.csdn.net/weixin_43470118/article/details/103056373


    我使用上述链接中的方法试了一下 好像回滚了,不知道这种方式使用有没有问题,大佬们可以看一下帮我解答一下,谢谢!!!!
    10 replies    2020-09-16 10:25:25 +08:00
    dovme
        1
    dovme  
       Sep 15, 2020
    方法上加 @Transactional 注解
    KevinBlandy
        2
    KevinBlandy  
       Sep 15, 2020
    互相调用的各个 Service 方法都添加 @Transactional 注解。
    colincat
        3
    colincat  
       Sep 15, 2020
    抽离出来一个单独 service 添加 @Transactional
    git00ll
        4
    git00ll  
       Sep 15, 2020
    两个 service 的方法上都加上事务注解,默认是 REQUIRED,调用的第二个 service 会共享第一个 service 的事务,即使用同一条 jdbc 连接。
    jiobanma
        5
    jiobanma  
    OP
       Sep 15, 2020
    @colincat #3 目前不能更改 service 的结构
    @KevinBlandy #2 不是互相调用,是同步调用两个 service
    colincat
        6
    colincat  
       Sep 15, 2020
    @jiobanma 单独提取出来一个 component,因为 spring 事务是基于代理实现的,了解一下底层更加有助于编码
    1107139144
        7
    1107139144  
       Sep 15, 2020
    把两个 service 里的方法整合在一个 service 。只 controller 里面调用一个 service
    jiobanma
        8
    jiobanma  
    OP
       Sep 15, 2020
    @1107139144 #7 这个 service 结构目前不能变动,不过按照附言里的方式手动回滚和提交事务已经实现了
    chen19
        9
    chen19  
       Sep 16, 2020
    两个 Service 方法都添加 @Transactional 注解,应该就可以了
    sdrzlyz
        10
    sdrzlyz  
       Sep 16, 2020
    serviceA 直接调用 serviceB 的话,两者不会在同一个事务里。

    如果是 spring 的话,serviceA 先 getBean(ServiceB),然后再调用
    About   ·   Help   ·   Advertise   ·   Blog   ·   API   ·   FAQ   ·   Solana   ·   5432 Online   Highest 6679   ·     Select Language
    创意工作者们的社区
    World is powered by solitude
    VERSION: 3.9.8.5 · 66ms · UTC 03:53 · PVG 11:53 · LAX 20:53 · JFK 23:53
    ♥ Do have faith in what you're doing.