Désactivation temporaire des contraintes de clé étrangère dans MySQL
Dans MySQL, les contraintes de clé étrangère renforcent l'intégrité référentielle, garantissant la cohérence des données entre les tables associées. Cependant, il existe des scénarios dans lesquels la désactivation temporaire de ces contraintes est nécessaire, par exemple lors de suppressions de modèles.
Considérez les modèles Django suivants avec des relations de clés étrangères mutuelles :
class Item(models.Model): style = models.ForeignKey('Style', on_delete=models.CASCADE) class Style(models.Model): item = models.ForeignKey('Item', on_delete=models.CASCADE)
Tentative de suppression d'une instance des deux modèles séquentiellement peut entraîner une erreur :
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()
Pour contourner cette contrainte de clé étrangère, vous pouvez la désactiver temporairement en utilisant l'une des méthodes suivantes :
1. DÉSACTIVER LES CLÉS :
ALTER TABLE myapp_item DISABLE KEYS;
Cette commande réactive les contraintes une fois la table rouverte ou fermée.
2. SET FOREIGN_KEY_CHECKS :
SET FOREIGN_KEY_CHECKS = 0; # Disable foreign key checks
N'oubliez pas de réactiver les contraintes après l'opération de suppression :
SET FOREIGN_KEY_CHECKS = 1; # Re-enable foreign key checks
Ce qui précède est le contenu détaillé de. pour plus d'informations, suivez d'autres articles connexes sur le site Web de PHP en chinois!