外键依赖检查

最近更新时间:2024-08-09 17:56:31

我的收藏

检查详情

MySQL/MariaDB/Percona/TDSQL-C MySQL/TDSQL MySQL/TDSQL TDStore 之间的数据同步:外键依赖只能设置为 NO ACTION、RESTRICT,设置为其他校验将报错,但用户可选择修复报错或者忽略报错继续任务。
部分库表迁移时,有外键依赖的表必须齐全。

外键依赖参数说明

MySQL 系类型的数据库在设置外键时,删除和更新有四个值可以选择。
CASCADE:父表进行删除或者更新记录时,子表会同步删除或更新关联记录。
SET NULL:父表进行删除或者更新记录时,子表会将关联记录的外键字段所在列设为 null(子表外键不能设为 not null)。
RESTRICT:父表执行删除或更新记录时,如果子表中有关联该父表的记录,则拒绝该父表删除请求。
NO ACTION:同 RESTRICT,也是首先检查外键。
SET DEFAULT:父表进行删除或者更新记录时,子表将外键列设置成一个默认的值,但 InnoDB 引擎不能识别。

同步场景-修改外键参数

数据同步中,外键依赖只能设置为 NO ACTION、RESTRICT,设置为其他校验将报错,但用户可选择修复报错或者忽略报错继续任务,如需修复报错参考后续指导操作。


Windows 操作指导

2. 在左侧目标树上选中要修改的表,在打开的表编辑界面上,单击外键页签,修改外键参数,如下图所示。

3. 修改完成后,单击保存
4. 重新执行校验任务。

Linux 操作指导

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. 重新执行校验任务。