首页  >  文章  >  数据库  >  为什么删除表时会出现“伪造外键约束失败”错误?

为什么删除表时会出现“伪造外键约束失败”错误?

Linda Hamilton
Linda Hamilton原创
2024-11-05 22:33:02655浏览

Why Does

“虚假外键约束失败”解释和解决

当遇到错误消息“ERROR 1217 (23000) at line 40: Cannot删除或更新父行:外键约束失败”在尝试删除表时,了解根本原因非常重要。尽管删除了对有问题表的外键引用的所有其他表,但错误仍然存​​在。

在这种情况下,问题是由于 MySQL 查询浏览器或 phpMyAdmin 对每个查询使用单独的连接而引起的。要解决此问题,应将所有 drop 语句合并为单个查询,如下所示:

SET FOREIGN_KEY_CHECKS=0;
DROP TABLE my_first_table_to_drop;
DROP TABLE my_second_table_to_drop;
SET FOREIGN_KEY_CHECKS=1;

通过这样做,可以暂时禁用外键检查,从而可以成功删除表。最后的 SET FOREIGN_KEY_CHECKS=1 语句重新启用外键检查,确保数据完整性。

需要注意的是,InnoDB 不支持跨模式外键。因此,该问题不是由当前数据库架构之外的任何外部引用引起的。

以上是为什么删除表时会出现“伪造外键约束失败”错误?的详细内容。更多信息请关注PHP中文网其他相关文章!

声明:
本文内容由网友自发贡献,版权归原作者所有,本站不承担相应法律责任。如您发现有涉嫌抄袭侵权的内容,请联系admin@php.cn