如何暂时禁用MySQL中的外键约束?

Mary-Kate Olsen
发布: 2024-11-07 09:23:03
原创
641 人浏览过

How to Temporarily Disable Foreign Key Constraints in MySQL?

暂时禁用 MySQL 中的外键约束

在 MySQL 中,外键约束强制引用完整性,确保相关表之间的数据一致性。但是,在某些情况下,需要暂时禁用这些约束,例如在模型删除期间。

考虑以下具有相互外键关系的 Django 模型:

class Item(models.Model):
    style = models.ForeignKey('Style', on_delete=models.CASCADE)

class Style(models.Model):
    item = models.ForeignKey('Item', on_delete=models.CASCADE)
登录后复制

尝试删除实例连续使用两个模型可能会导致错误:

cursor.execute("DELETE FROM myapp_item WHERE n = %s", n)
transaction.commit_unless_managed()  # foreign key constraint fails here

cursor.execute("DELETE FROM myapp_style WHERE n = %s", n)
transaction.commit_unless_managed()
登录后复制

要绕过此外键约束,您可以使用以下方法之一暂时禁用它:

1.禁用键:

ALTER TABLE myapp_item DISABLE KEYS;
登录后复制

一旦重新打开或关闭表,此命令将重新启用约束。

2. SET FOREIGN_KEY_CHECKS:

SET FOREIGN_KEY_CHECKS = 0;  # Disable foreign key checks
登录后复制

删除操作后记得重新启用约束:

SET FOREIGN_KEY_CHECKS = 1;  # Re-enable foreign key checks
登录后复制

以上是如何暂时禁用MySQL中的外键约束?的详细内容。更多信息请关注PHP中文网其他相关文章!

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