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 racine cause.
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 pouvoir créer avec succès la table "bar" avec la contrainte de clé étrangère, en résolvant l'erreur 150.
Clause de non-responsabilité: Toutes les ressources fournies proviennent en partie d'Internet. En cas de violation de vos droits d'auteur ou d'autres droits et intérêts, veuillez expliquer les raisons détaillées et fournir une preuve du droit d'auteur ou des droits et intérêts, puis l'envoyer à l'adresse e-mail : [email protected]. Nous nous en occuperons pour vous dans les plus brefs délais.
Copyright© 2022 湘ICP备2022001581号-3