“虚假外键约束失败”解释和解决
当遇到错误消息“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中文网其他相关文章!