Heim > Datenbank > MySQL-Tutorial > Warum erhalte ich die MySQL-Fehlermeldung „Angegebener Schlüssel war zu lang'?

Warum erhalte ich die MySQL-Fehlermeldung „Angegebener Schlüssel war zu lang'?

Susan Sarandon
Freigeben: 2024-12-09 12:24:15
Original
173 Leute haben es durchsucht

Why Am I Getting the MySQL Error

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`;
Nach dem Login kopieren

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))
Nach dem Login kopieren

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!

Quelle:php.cn
Erklärung dieser Website
Der Inhalt dieses Artikels wird freiwillig von Internetnutzern beigesteuert und das Urheberrecht liegt beim ursprünglichen Autor. Diese Website übernimmt keine entsprechende rechtliche Verantwortung. Wenn Sie Inhalte finden, bei denen der Verdacht eines Plagiats oder einer Rechtsverletzung besteht, wenden Sie sich bitte an admin@php.cn
Neueste Artikel des Autors
Beliebte Tutorials
Mehr>
Neueste Downloads
Mehr>
Web-Effekte
Quellcode der Website
Website-Materialien
Frontend-Vorlage