微信搜索【程序员囧辉】,关注这个坚持分享技术干货的程序员。
问题
在MySQL中删除一张表或一条数据的时候,出现
[Err] 1451 -Cannot delete or update a parent row: a foreign key constraint fails (...)
这是因为MySQL中设置了foreign key关联,造成无法更新或删除数据。可以通过设置FOREIGN_KEY_CHECKS变量来避免这种情况。
解决
我们可以使用
SET FOREIGN_KEY_CHECKS=0;
来禁用外键约束.
之后再用
SET FOREIGN_KEY_CHECKS=1;
来启动外键约束.
查看当前FOREIGN_KEY_CHECKS的值可用如下命令
SELECT @@FOREIGN_KEY_CHECKS;
推荐阅读
另外,我还准备了很多大厂面试资料、0基础自学教程,由于不能放外链,所以有需要的小伙伴去公众号【程序员囧辉】回复【资料】自行获取好了。
解决MySQL外键约束错误:禁用与启用FOREIGN_KEY_CHECKS

本文介绍在MySQL中遇到无法删除表或数据的错误时,通过调整FOREIGN_KEY_CHECKS变量来解决外键约束问题的方法。包括禁用外键约束以删除数据,然后重新启用它们。并提供了检查当前状态的命令。
2474

被折叠的 条评论
为什么被折叠?



