Erreur de clé étrangère MySql 150 : une énigme déroutante
Lorsque vous essayez de créer les tables "foo" et "bar" avec des relations de clé étrangère , vous rencontrez l'erreur 1005 (HY000) en référence à l'erreur 150. Cette erreur peut être frustrante et vous laisse perplexe quant à la cause première.
Selon la documentation MySQL sur les contraintes de clé étrangère, le problème survient lors de la recréation d'une table supprimée contenant des références de clé étrangère. La table doit être conforme aux contraintes de clé étrangère en ayant des noms et des types de colonnes correspondants, ainsi que des index sur les clés référencées. Si ces conditions ne sont pas remplies, MySQL renvoie l'erreur 1005, avec une erreur sous-jacente 150.
Il est probable que votre erreur soit due au fait que la table "foo" n'est pas définie comme une table InnoDB. La documentation MySQL indique explicitement que les deux tables doivent être des tables InnoDB et non temporaires.
En modifiant la requête de création de table "foo" pour spécifier le moteur InnoDB :
mysql> CREATE TABLE foo(id INT PRIMARY KEY) ENGINE=InnoDB;
Vous devriez être capable de créer avec succès la table "bar" avec la contrainte de clé étrangère, résolvant l'erreur 150.
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!