检查详情
MySQL/MariaDB/Percona/TDSQL-C MySQL/TDSQL MySQL/TDSQL TDStore 之间的数据迁移:DTS 默认支持 RESTRICT,NO ACTION,如果源库中存在 CASCADE、SET NULL、SET DEFAULT 这三种外键数据,也可以迁移,需要在校验项中开启外键依赖开关。
部分库表迁移时,有外键依赖的表必须齐全。
外键依赖参数说明
MySQL 系类型的数据库在设置外键时,删除和更新有四个值可以选择。
CASCADE
:父表进行删除或者更新记录时,子表会同步删除或更新关联记录。SET NULL
:父表进行删除或者更新记录时,子表会将关联记录的外键字段所在列设为 null
(子表外键不能设为 not null
)。RESTRICT
:父表执行删除或更新记录时,如果子表中有关联该父表的记录,则拒绝该父表删除请求。NO ACTION
:同 RESTRICT,也是首先检查外键。SET DEFAULT
:父表进行删除或者更新记录时,子表将外键列设置成一个默认的值,但 InnoDB 引擎不能识别。迁移场景-开启外键依赖关系迁移
DTS 默认支持 RESTRICT,NO ACTION,如果源数据库迁移的数据中存在其他类型的外键依赖配置,校验系统会提示报错,需要用户按照如下指导在校验项中开启外键依赖。
1. 在数据迁移操作中的校验任务页面,源库存在外键依赖规则 CASCADE、SET NULL、SET DEFAULT,校验项报错,查看校验项详情。
2. 根据情况选择忽略报错,或者迁移外键依赖关系。确认无误后勾选风险知会,单击确认。
选项 | 说明 |
屏蔽外键依赖检查报错 | 勾选后忽略已有的校验报错,继续迁移任务。 源库中存在外键规则 CASCADE、SET NULL、SET DEFAULT,仍可以进行迁移,但屏蔽报错后可能出现因为父表进行删除或者更新操作,导致目标库和源库的数据结果不一致。 |
迁移外键依赖关系 | 勾选后支持迁移 CASCADE、SET NULL、SET DEFAULT 类型的外键依赖关系,但 DTS 仅在任务发起时检查外键依赖关系,保证存量数据迁移到目标库的一致性。 1. 任务迁移过程中不要修改源库中的外键依赖规则,否则将导致目标库数据与源库不一致。
如在迁移过程中,将源库外键规则从 CASCADE 修改为 NO ACTION,目标库中父表的更新及删除操作仍会影响子表。 2. 在外键规则为 CASCADE 或 SET NULL 时,勾选迁移外键依赖关系后,在全量迁移阶段会对源库短暂加表锁,影响时间约 5-10 秒。 3. 为了保证数据的一致性,在增量同步阶段,对外键相关表的数据传输将从行级同步降级为表级同步,性能会有所下降。 |
3. 重新执行校验任务。
Windows 操作指导
1. 登录源数据库 DMC 平台。
2. 在左侧目标树上选中要修改的表,在打开的表编辑界面上,单击外键页签,修改外键参数,如下图所示。
3. 修改完成后,单击保存。
4. 重新执行校验任务。
Linux 操作指导
1. 登录源数据库。
2. 删除原来的外键设置。
alter table `表名称1` drop foreign key `外键名称1`;
3. 重新添加外键设置。
alter table `表名称1` add constraint `外键名称2` foreign key `表名称1`(`列名1`) references `表名称2`(`列名1`)on update no action on delete no action;
4. 重新执行校验任务。
完善迁移对象
修改迁移任务配置,在迁移对象中勾选具有关联关系的对象。
1. 在 DTS 控制台,选择对应的迁移任务,在操作列选择更多 > 修改。
2. 在迁移对象中勾选具有关联关系的对象。
3. 重新执行校验任务。