暫時停用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