MySQL如何更新主键的同时更新外键?

发布于 09-11 22:15 字数 464 浏览 22 评论 0

A表主键是idB表里面有一个字段是a_id指向A.id,现在A有一条记录

id
123

B有一条记录

ida_id
999123

比如我想更新A.id = 333,如何让B中的a_id = 123同步更新成333

如果你对这篇内容有疑问,欢迎到本站社区发帖提问 参与讨论,获取更多帮助,或者扫码二维码加入 Web 技术交流群。

扫码二维码加入Web技术交流群

发布评论

需要 登录 才能够评论, 你可以免费 注册 一个本站的账号。

评论(1

飞烟轻若梦2022-09-18 22:15:08

实际情况中一般情况下是不允许修改id的,实在需要修改的话需要用两条update语句,并且临时关闭外键约束

SET FOREIGN_KEY_CHECKS = 0;
update A as a set a.id = 333 where a.id = 123;
update B as b set b.a_id = 333 where b.a_id = 123;
SET FOREIGN_KEY_CHECKS = 1;

另外一种方法,删除之前的外键约束,添加新的外键约束时使用ON UPDATE CASCADE可以实现自动更新外键字段。

ALTER TABLE B ADD FOREIGN KEY (a_id) REFERENCES A(id) ON UPDATE CASCADE;
~没有更多了~
我们使用 Cookies 和其他技术来定制您的体验包括您的登录状态等。通过阅读我们的 隐私政策 了解更多相关信息。 单击 接受 或继续使用网站,即表示您同意使用 Cookies 和您的相关数据。
原文