TCC中如果try方法内部有多个sql操作,由于分库不能在一个事务完成怎么办?

假如try方法内部是一批数据库插入和更新的操作,相关的表在不同的库上,所以不能做成一个本地事务,这种情况怎么办?
比如try方法操作后,有部分数据库操作提交,有部分没有,cancel也不好处理啊

阅读 2k
2 个回答

TCC的try阶段是尝试阶段,都成功后才则有TCC推动执行各个本地的confirm,会一直尝试。

这里如果你是单个应用写不同的数据库,这个不能叫分布式事务,而且本身设计层面也不应该这么做。分布式事务是一个应用调用多个其他应用共同组成事务,要么都成功,要么都失败。

新手上路,请多包涵

try 方法里面可以按照正常的多数据库源调用,后面一个操作是否执行依赖前一操作的结果,做个判断,如果前一个操作失败,则直接异常。confirm 里面可以执行空方法,cancel 方法里面可以执行具体的回滚操作。个人认为想要看看你操作数据是什么的逻辑 ,来编排你的cancel方法。

撰写回答
你尚未登录,登录后可以
  • 和开发者交流问题的细节
  • 关注并接收问题和回答的更新提醒
  • 参与内容的编辑和改进,让解决方法与时俱进
推荐问题