开发者社区 > 云原生 > 中间件 > 正文

SeaTa只根据主键定位数据,那就会备份所有分表的数据吗?

SeaTa只根据主键定位数据,那就会备份所有分表的数据吗?
e46aaa53a15e295f362270a04018b29c.png

展开
收起
青城山下庄文杰 2023-07-21 16:19:52 76 0
3 条回答
写回答
取消 提交回答
  • Seata 只根据主键定位数据,但它并不会备份所有分表的数据。

    在 Seata 中,分布式事务的概念是基于主键来实现的。当一个分布式事务涉及到多个数据库或数据源时,Seata 会通过记录和保存每个参与者(即每个数据库或数据源)的操作日志,以便在回滚或提交时进行协调。

    当执行分布式事务时,Seata 会根据业务逻辑和事务上下文,将相关的数据操作(插入、更新、删除等)发送给各个参与者。这些操作只针对相关的数据行(根据主键定位),而不是备份整个分表的数据。

    因此,Seata 并不会备份所有分表的数据,而是通过分布式事务协调各个参与者的数据操作,确保分布式事务的一致性和隔离性。

    2023-07-28 10:46:39
    赞同 展开评论 打赏
  • 代理层再逻辑层之下就没这个问题-此回答整理自钉群“3群-Seata 开源讨论群”

    2023-07-24 12:55:45
    赞同 展开评论 打赏
  • 北京阿里云ACE会长

    Seata并不会真正备份数据,它仅记录数据的变更,用于回滚事务。

    当事务回滚时,Seata根据主键(通常是id)去定位数据行,执行相应的SQL来回滚。

    由于Seata仅根据主键ID去定位数据,所以:

    如果不同的分表中有相同ID的数据,Seata会将这些分表的数据都备份
    如果分表中ID不重复,Seata就只会备份实际修改的数据对应的那张分表
    举个例子:

    如果有user和order两张表,user分为user_1表和user_2表:

    user_1表有ID 1、2、3的数据
    user_2表有ID 4、5、6的数据
    在一个事务中修改了:

    user_1表中ID为1的记录
    order表中ID为4的记录
    此时:

    Seata会备份user_1表中的ID为1 的那条记录

    Seata也会备份order表中的ID为4 的那条记录

    Seata不会备份user_2表,因为事务没有修改user_2表

    2023-07-23 18:03:00
    赞同 展开评论 打赏

为企业提供高效、稳定、易扩展的中间件产品。

相关电子书

更多
《Seata 1.3 新特性以及如何参与社区》 立即下载
低代码开发师(初级)实战教程 立即下载
阿里巴巴DevOps 最佳实践手册 立即下载