暂时禁用 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中文网其他相关文章!