MySql-Fehler: „Specified Key Was Too Long“
Bei der Abfrage von MySql-Datenbanken kann der Fehler „Specified Key Was Too Long“ auftreten beim Erstellen von Tabellen mit langen Schlüssellängen. Dieses Problem tritt häufig auf, wenn mehrere Spalten in einem einzelnen Index verwendet werden.
Fallstudie mit der pds_core_menu_items-Tabelle
Die bereitgestellte Abfrage versucht, eine Tabelle mit einem zusammengesetzten Index für zu erstellen Spalten parent_menu_id, menu_link, Plugin und Alias. Bei diesen Spalten handelt es sich um VARCHAR(255)-Datentypen.
Erläuterung des Problems
Wie @Devart erwähnte, überschreitet die Gesamtlänge dieser Spalten die maximal zulässige Schlüssellänge von 1000 Byte. Aufgrund dieser Einschränkung schlägt die Indexerstellung mit dem angegebenen Fehler fehl.
Lösung: Präfixindizierung
Die beste Vorgehensweise zur Lösung dieses Problems ist die Verwendung der Präfixindizierung. Durch die Verwendung von Präfixindizes wird nur ein linker Teilstring der Originaldaten indiziert, wodurch die Indexgröße erheblich reduziert und die Effizienz verbessert wird.
Bestimmen der optimalen Präfixlänge
Zur Bestimmung der Um die optimale Präfixlänge für jede Spalte zu ermitteln, führen Sie die folgende Abfrage aus:
SELECT ROUND(SUM(LENGTH(`column_name`)<10)*100/COUNT(`column_name`),2) AS pct_length_10, ROUND(SUM(LENGTH(`column_name`)<20)*100/COUNT(`column_name`),2) AS pct_length_20, ROUND(SUM(LENGTH(`column_name`)<50)*100/COUNT(`column_name`),2) AS pct_length_50, ROUND(SUM(LENGTH(`column_name`)<100)*100/COUNT(`column_name`),2) AS pct_length_100 FROM `table_name`;
Ersetzen Sie Spaltenname durch die zu analysierende Spalte und Tabellenname durch die Tabelle enthält die Spalte. Analysieren Sie die Ausgabe, um die kleinste Teilzeichenfolgenlänge zu ermitteln, die den höchsten Prozentsatz an Zeilen abdeckt.
Aktualisierte Abfrage
Im bereitgestellten Beispiel würde die Indizierung einer Teilzeichenfolge mit 50 Zeichen ausreichen , wie aus den Abfrageergebnissen hervorgeht. Hier ist die aktualisierte Abfrage:
KEY `index` (`parent_menu_id`,`menu_link`(50),`plugin`(50),`alias`(50))
Zusätzlicher Hinweis
Der Fehler kann auch bei Verwendung der Datentypen INT(1) und INT(32) auftreten. Während diese Datentypen keinen Einfluss auf die Speichergröße oder den Wertebereich haben, können sie sich darauf auswirken, wie Werte angezeigt werden, wenn die Option ZEROFILL verwendet wird.
Das obige ist der detaillierte Inhalt vonWarum erhalte ich die MySQL-Fehlermeldung „Angegebener Schlüssel war zu lang'?. Für weitere Informationen folgen Sie bitte anderen verwandten Artikeln auf der PHP chinesischen Website!