为什么在 MySQL 中删除表时出现'ERROR 1217 (23000)...外键约束失败”?

Barbara Streisand
发布: 2024-11-05 08:35:02
原创
306 人浏览过

Why Do I Get

MySQL:处理虚假外键约束失败

遇到“ERROR 1217 (23000)...外键约束失败”错误尽管看似已删除所有相应的外键约束,但尝试删除 MySQL 表可能会令人费解。

要解决此问题,请考虑以下可能性:

数据持久性由于多个连接

使用 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;
登录后复制

通过将所有 drop 语句分组在一起,在删除表时会禁用外键约束。附加语句 SET FOREIGN_KEY_CHECKS=1 作为操作完成后重新启用外键检查的附加预防措施。

以上是为什么在 MySQL 中删除表时出现'ERROR 1217 (23000)...外键约束失败”?的详细内容。更多信息请关注PHP中文网其他相关文章!

来源:php.cn
本站声明
本文内容由网友自发贡献,版权归原作者所有,本站不承担相应法律责任。如您发现有涉嫌抄袭侵权的内容,请联系admin@php.cn
作者最新文章
热门教程
更多>
最新下载
更多>
网站特效
网站源码
网站素材
前端模板
关于我们 免责声明 Sitemap
PHP中文网:公益在线PHP培训,帮助PHP学习者快速成长!