Lors de l'ajout d'une contrainte de clé unique à une table MySQL contenant des colonnes avec des types de données VARCHAR, vous pouvez rencontrer l'erreur suivante :
#1071 - Specified key was too long; max key length is 767 bytes
Cette erreur se produit même si la longueur combinée des colonnes VARCHAR semble être inférieure au maximum longueur de clé, qui est de 767 octets dans les versions MySQL 5.6 et antérieures.
La limitation de préfixe indiquée pour les tables InnoDB dans les versions MySQL 5.6 et inférieures est de 767 octets. Cela signifie que la longueur combinée des préfixes des colonnes clés ne peut pas dépasser cette limite. Pour les tables MyISAM, la longueur maximale de clé est de 1 000 octets.
Dans l'exemple fourni, les colonnes colonne1 et colonne2 ont respectivement les types de données VARCHAR(20) et VARCHAR(500). Cela impliquerait une longueur combinée de 522 octets, laissant une marge confortable en dessous de la limite de 767 octets. Cependant, le message d'erreur indique que ce n'est pas le cas.
La raison de l'erreur est que MySQL utilise un codage multi-octets de longueur variable pour les colonnes VARCHAR. Cela signifie que chaque caractère d'une colonne VARCHAR peut être représenté par un nombre variable d'octets. Par exemple, une colonne VARCHAR(20) peut contenir jusqu'à 20 caractères, mais chaque caractère peut occuper jusqu'à 3 octets s'il est codé dans un format de caractères larges tel que UTF-8mb4.
En conséquence , la longueur réelle de la clé est déterminée par la longueur maximale possible des chaînes de caractères pouvant être stockées dans chaque colonne. Dans ce cas, la longueur maximale possible des chaînes de caractères dans la colonne1 et la colonne2 est respectivement de 20 3 octets = 60 octets et de 500 3 octets = 1500 octets. Cela donne un total de 60 1500 = 1560 octets, ce qui dépasse la longueur de clé maximale de 767 octets.
Pour résoudre ce problème, vous pouvez envisager les solutions suivantes :
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!