MySQL-Schlüssellängenbeschränkung und ihre Behebung
Beim Versuch, einen eindeutigen Index für zwei VARCHAR-Spalten zu erstellen, stoßen Benutzer möglicherweise auf den Fehler „# 1071 – Der angegebene Schlüssel war zu lang; die maximale Schlüssellänge beträgt 767 Bytes. Dieser Fehler ist auf die Beschränkungen von MySQL hinsichtlich der Schlüssellänge zurückzuführen.
Grundlegendes zur Schlüssellängenbeschränkung
In MySQL-Versionen 5.6 und früher gibt es eine maximale Schlüssellänge von 767 Bytes für InnoDB-Tabellen. Diese Grenze gilt für die Kombination aller indizierten Felder innerhalb eines eindeutigen Schlüssels. Für MyISAM-Tabellen beträgt diese Grenze 1.000 Bytes.
UTF-8-Zeichenkodierungsfaktor
Bei der Verwendung der UTF-8-Zeichenkodierung (utf8mb4) ist es wichtig, dies zu beachten es verwendet bis zu vier Bytes, um ein einzelnes Zeichen darzustellen. Dadurch wird die maximale Indexpräfixlänge von 767 Byte effektiv auf 191 Zeichen für utf8mb4-codierte Felder reduziert.
Mögliche Lösungen
ALTER TABLE `mytable` ADD UNIQUE ( column1(15), column2(200) );
In MySQL Version 5.7 und höher wurde die maximale Schlüssellänge auf 3072 Bytes erhöht, was mehr Flexibilität beim Umgang mit großen Schlüsseln bietet. Es ist jedoch immer noch wichtig, Zeichenkodierungsfaktoren und Datenmodelloptimierung zu berücksichtigen, um Schlüssellängenfehler zu vermeiden.
Das obige ist der detaillierte Inhalt vonWarum ist mein MySQL Unique Index zu lang und wie kann ich das Problem beheben?. Für weitere Informationen folgen Sie bitte anderen verwandten Artikeln auf der PHP chinesischen Website!