Maison >base de données >tutoriel mysql >Erreurs MySQL 150 et 1005 : pourquoi ne puis-je pas créer de relations de clés étrangères ?

Erreurs MySQL 150 et 1005 : pourquoi ne puis-je pas créer de relations de clés étrangères ?

DDD
DDDoriginal
2024-11-26 13:37:10823parcourir

MySQL Error 150 & 1005: Why Can't I Create Foreign Key Relationships?

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!

Déclaration:
Le contenu de cet article est volontairement contribué par les internautes et les droits d'auteur appartiennent à l'auteur original. Ce site n'assume aucune responsabilité légale correspondante. Si vous trouvez un contenu suspecté de plagiat ou de contrefaçon, veuillez contacter admin@php.cn