Maison > base de données > tutoriel mysql > Pourquoi est-ce que je reçois une erreur de clé en double lors de la création d'une table MySQL ?

Pourquoi est-ce que je reçois une erreur de clé en double lors de la création d'une table MySQL ?

Barbara Streisand
Libérer: 2024-11-29 02:14:08
original
450 Les gens l'ont consulté

Why Am I Getting a Duplicate Key Error When Creating a MySQL Table?

Erreur de clé en double dans la commande CREATE TABLE

Q1. Erreur 1022 : Impossible d'écrire ; clé en double dans la table

Je rencontre une erreur 1022 lors de l'exécution d'une commande CREATE TABLE en raison de clés en double. J'ai examiné la requête, mais je ne parviens pas à identifier la cause.

Requête :

CREATE TABLE IF NOT EXISTS  `apptwo`.`usercircle` (
 `idUserCircle` MEDIUMINT NOT NULL ,
 `userId` MEDIUMINT NULL ,
 `circleId` MEDIUMINT NULL ,
 `authUser` BINARY NULL ,
 `authOwner` BINARY NULL ,
 `startDate` DATETIME NULL ,
 `endDate` DATETIME NULL ,
 PRIMARY KEY (  `idUserCircle` ) ,
 INDEX  `iduser_idx` (  `userId` ASC ) ,
 INDEX  `idcategory_idx` (  `circleId` ASC ) ,
 CONSTRAINT  `iduser` FOREIGN KEY (  `userId` ) REFERENCES  `apptwo`.`user` (
`idUser`
) ON DELETE NO ACTION ON UPDATE NO ACTION ,
 CONSTRAINT  `idcategory` FOREIGN KEY (  `circleId` ) REFERENCES  `apptwo`.`circle` (
`idCircle`
) ON DELETE NO ACTION ON UPDATE NO ACTION
) ENGINE = INNODB;
Copier après la connexion

Q2. Où se produit la duplication ?

A1. Conflit de nom de contrainte

L'erreur provient probablement de noms de contrainte en double. Les contraintes doivent être uniques dans l'ensemble de la base de données, pas seulement dans une table spécifique.

Dans ce cas, il semble qu'il existe déjà des contraintes nommées iduser et/ou idcategory dans la base de données. Renommer ces contraintes résoudra le problème.

Q3. Comment puis-je identifier les contraintes existantes ?

A2. Requête pour localiser les contraintes

Pour identifier où les contraintes sont actuellement utilisées, exécutez la requête suivante :

SELECT `TABLE_SCHEMA`, `TABLE_NAME`
FROM `information_schema`.`KEY_COLUMN_USAGE`
WHERE `CONSTRAINT_NAME` IN ('iduser', 'idcategory');
Copier après la connexion

Cette requête renverra les noms de schéma et de table où les contraintes sont appliquées .

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!

source:php.cn
Déclaration de ce site Web
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
Derniers articles par auteur
Tutoriels populaires
Plus>
Derniers téléchargements
Plus>
effets Web
Code source du site Web
Matériel du site Web
Modèle frontal