Maison >base de données >tutoriel mysql >Pourquoi mon index unique MySQL est-il trop long et comment puis-je y remédier ?
Limitation de la longueur des clés MySQL et son correctif
Lors de la tentative de création d'un index unique sur deux colonnes VARCHAR, les utilisateurs peuvent rencontrer l'erreur "# 1071 - La clé spécifiée était trop longue ; la longueur maximale de la clé est de 767 octets". Cette erreur provient des limitations de MySQL sur la longueur des clés.
Comprendre la limite de longueur de clé
Dans les versions MySQL 5.6 et antérieures, la longueur de clé maximale est de 767 octets pour les tables InnoDB. Cette limite s'applique à la combinaison de tous les champs indexés au sein d'une clé unique. Pour les tables MyISAM, cette limite est de 1 000 octets.
Facteur d'encodage de caractères UTF-8
Lors de l'utilisation de l'encodage de caractères UTF-8 (utf8mb4), il est important de noter que il utilise jusqu'à quatre octets pour représenter un seul caractère. En conséquence, la longueur maximale du préfixe d'index de 767 octets est effectivement réduite à 191 caractères pour les champs codés en utf8mb4.
Solutions possibles
ALTER TABLE `mytable` ADD UNIQUE ( column1(15), column2(200) );
Dans MySQL version 5.7 et versions ultérieures, la longueur maximale de la clé a été augmentée à 3072 octets, offrant plus de flexibilité lors du traitement de clés volumineuses. Cependant, il est toujours important de prendre en compte les facteurs de codage des caractères et l'optimisation du modèle de données pour éviter les erreurs de longueur de clé.
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!