Maison >base de données >tutoriel mysql >Erreur lors du changement de nom de 'table_name' en 'new_table_name' (errno : 150) - Comment résoudre l'erreur MySQL : erreur lors du renommage de 'table_name' en 'new_table_name', numéro d'erreur : 150

Erreur lors du changement de nom de 'table_name' en 'new_table_name' (errno : 150) - Comment résoudre l'erreur MySQL : erreur lors du renommage de 'table_name' en 'new_table_name', numéro d'erreur : 150

WBOY
WBOYoriginal
2023-10-05 08:18:13924parcourir

Error on rename of 'table_name' to 'new_table_name' (errno: 150) - 如何解决MySQL报错:重命名'table_name'为'new_table_name'时出错,错误编号:150

Comment résoudre l'erreur MySQL : une erreur s'est produite lors du renommage de 'table_name' en 'new_table_name', numéro d'erreur : 150, des exemples de code spécifiques sont nécessaires

Lors de l'utilisation de la base de données MySQL, nous rencontrons souvent diverses erreurs. L'une des erreurs courantes consiste à renommer une table de données. La base de données MySQL renverra l'erreur numéro 150 lors de l'exécution d'une opération de changement de nom. Cette erreur est généralement causée par des contraintes de clé étrangère.

Les contraintes de clés étrangères sont un mécanisme utilisé pour assurer la corrélation entre les tables. Lorsque nous voulons renommer une table, si la table a une association de clé étrangère, MySQL nous empêchera de la renommer directement. Au lieu de cela, une erreur 150 sera signalée. Alors comment résoudre ce problème ? Quelques exemples de codes spécifiques sont donnés ci-dessous.

Tout d’abord, créons deux tableaux simples pour démontrer cette erreur.

CREATE TABLE table1 (
   id INT PRIMARY KEY
);

CREATE TABLE table2 (
   id INT PRIMARY KEY,
   table1_id INT,
   FOREIGN KEY (table1_id) REFERENCES table1(id)
);

Dans le code ci-dessus, nous avons créé deux tables, table1 et table2. Il existe une association de clé étrangère entre ces deux tables et le champ table1_id de table2 fait référence au champ id de table1.

Ensuite, nous essayons de renommer la table table1 :

RENAME TABLE table1 TO new_table1;

Lorsque nous exécutons le code ci-dessus, MySQL renvoie l'erreur 150. Étant donné que table2 dépend des contraintes de clé étrangère de table1, MySQL ne vous permet pas de renommer directement table1.

Alors comment résoudre ce problème ? Il existe deux manières de résoudre cette erreur.

Méthode 1 : Supprimez d'abord la contrainte de clé étrangère, puis renommez-la.

ALTER TABLE table2 DROP FOREIGN KEY table2_ibfk_1;
RENAME TABLE table1 TO new_table1;

Dans le code ci-dessus, nous avons supprimé les contraintes de clé étrangère de la table table2 en utilisant l'instruction ALTER TABLE. Ensuite, nous procédons à l'opération de renommage. Cette fois, MySQL effectuera avec succès l'opération de renommage.

Méthode 2 : utilisez l'instruction ALTER TABLE pour modifier simultanément le nom de la table et les contraintes de clé étrangère.

ALTER TABLE table1 RENAME new_table1;
ALTER TABLE table2 DROP FOREIGN KEY table2_ibfk_1;
ALTER TABLE new_table1 ADD CONSTRAINT table2_fk FOREIGN KEY (id) REFERENCES table2(table1_id);

Dans le code ci-dessus, nous utilisons d'abord l'instruction ALTER TABLE pour renommer la table table1 en new_table1. Ensuite, nous avons supprimé la contrainte de clé étrangère de la table table2. Enfin, nous avons réajouté les contraintes de clé étrangère à l'aide de l'instruction ALTER TABLE pour garantir que l'association de clé étrangère existe toujours.

Grâce aux deux méthodes ci-dessus, nous pouvons résoudre avec succès le problème de l'erreur MySQL 150. Mais il convient de noter qu'avant de renommer une table, vous devez vous assurer qu'aucune autre table ne dépend des contraintes de clé étrangère de la table. Sinon, nous devons d'abord supprimer les contraintes de clé étrangère pertinentes, puis effectuer l'opération de renommage.

En bref, les erreurs sont inévitables lors de l'utilisation de la base de données MySQL. Lorsque nous rencontrons un problème similaire à l’erreur numéro 150, nous pouvons résoudre le problème grâce aux solutions ci-dessus. J'espère que les exemples de code spécifiques ci-dessus pourront vous aider à résoudre l'erreur qui se produit lorsque MySQL renomme la table.

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