Maison >base de données >tutoriel mysql >Pourquoi est-ce que j'obtiens l'erreur MySQL n° 1071 : longueur maximale de clé dépassée lors de la création d'une clé unique ?

Pourquoi est-ce que j'obtiens l'erreur MySQL n° 1071 : longueur maximale de clé dépassée lors de la création d'une clé unique ?

DDD
DDDoriginal
2024-12-14 08:04:11245parcourir

Why am I getting MySQL Error #1071: Maximum Key Length Exceeded when creating a unique key?

Erreur MySQL n° 1071 : longueur maximale de clé dépassée

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.

Cause de l'erreur

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.

Explication

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.

Solutions

Pour résoudre ce problème, vous pouvez envisager les solutions suivantes :

  • Réduisez les longueurs maximales des colonnes VARCHAR. Pour Par exemple, vous pouvez modifier le type de données de la colonne 1 en VARCHAR(15).
  • Utilisez un préfixe de clé plus court. Au lieu d'indexer l'intégralité du champ de la colonne2, vous pouvez en utiliser uniquement un sous-ensemble. , comme column2(200).
  • Utilisez un moteur de table différent qui prend en charge des longueurs de clé plus longues. Les tables MyISAM ont un maximum longueur de clé de 1 000 octets, ce qui peut être suffisant pour vos besoins.
  • Mettez à niveau vers MySQL version 5.7 ou ultérieure. MySQL 5.7 et les versions ultérieures ont une longueur de clé maximale de 3 072 octets, ce qui fournit plus de flexibilité.

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