”工欲善其事,必先利其器。“—孔子《论语.录灵公》
首页 > 编程 > 如何暂时禁用MySQL中的外键约束?

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

发布于2024-11-18
浏览:107

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。 DISABLE KEYS:

ALTER TABLE myapp_item DISABLE KEYS;

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

2.设置 FOREIGN_KEY_CHECKS:

SET FOREIGN_KEY_CHECKS = 0;  # Disable foreign key checks

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

SET FOREIGN_KEY_CHECKS = 1;  # Re-enable foreign key checks
最新教程 更多>

免责声明: 提供的所有资源部分来自互联网,如果有侵犯您的版权或其他权益,请说明详细缘由并提供版权或权益证明然后发到邮箱:[email protected] 我们会第一时间内为您处理。

Copyright© 2022 湘ICP备2022001581号-3