Problem:
Sie sind Beim Erstellen einer MySQL-Tabelle mit einem bestimmten Wert tritt der Fehler „Angegebener Schlüssel war zu lang; maximale Schlüssellänge beträgt 1000 Bytes“ auf Abfrage. Bei dieser Abfrage wird eine Tabelle mit mehreren Spalten und einem kombinierten Index für einige davon erstellt.
Erklärung:
Dieser Fehler tritt auf, wenn die Gesamtlänge der indizierten Spalten größer ist Die in MySQL maximal zulässige Schlüssellänge beträgt 1000 Byte. In diesem Fall erstreckt sich der Schlüssel „index“ über vier Spalten mit VARCHAR-Datentypen, die jeweils eine maximale Länge von 255 Zeichen haben.
Lösung:
As Wie in der bereitgestellten Lösung erwähnt, ist die Hauptursache für diesen Fehler die übermäßige Länge der indizierten Spalten. Um dieses Problem zu beheben, wird die Verwendung von Präfixindizes empfohlen, bei denen nur ein Teil der Daten indiziert wird. Dies wird dadurch erreicht, dass bei der Indexdefinition für jede indizierte Spalte eine Länge angegeben wird. Zum Beispiel:
... KEY `index` (`parent_menu_id`,`menu_link`(50),`plugin`(50),`alias`(50)) ...
Bestimmen der optimalen Präfixlänge:
Um die am besten geeignete Präfixlänge für jede Spalte zu bestimmen, wird empfohlen, die Datenverteilung zu analysieren. Sie können eine Abfrage wie diese verwenden:
SELECT ROUND(SUM(LENGTH(`menu_link`)<10)*100/COUNT(`menu_link`),2) AS pct_length_10, ROUND(SUM(LENGTH(`menu_link`)<20)*100/COUNT(`menu_link`),2) AS pct_length_20, ROUND(SUM(LENGTH(`menu_link`)<50)*100/COUNT(`menu_link`),2) AS pct_length_50, ROUND(SUM(LENGTH(`menu_link`)<100)*100/COUNT(`menu_link`),2) AS pct_length_100 FROM `pds_core_menu_items`;
Diese Abfrage liefert den Prozentsatz der Zeilen mit Zeichenfolgen, die kleiner oder gleich einer bestimmten Länge sind. Basierend auf diesen Ergebnissen können Sie eine Präfixlänge wählen, die einen erheblichen Teil der Daten abdeckt, ohne übermäßigen Speicherplatz zu verschwenden. Wenn beispielsweise 80 % der Zeichenfolgen weniger als 20 Zeichen lang sind, kann eine Präfixlänge von 50 ausreichend sein.
Zusätzlicher Hinweis:
Es ist auch wichtig, Folgendes zu beachten Beachten Sie, dass die in der ursprünglichen Abfrage verwendeten Datentypen INT(1) und INT(32) keine Auswirkungen auf die Speicherung oder den Wertebereich haben. INT ist immer ein 32-Bit-Ganzzahltyp, der Werte von -2.147.483.648 bis 2.147.483.647 zulässt. Das numerische Argument wirkt sich in diesen Fällen hauptsächlich auf die Anzeigeauffüllung aus und hat keine Auswirkung auf den zugrunde liegenden Speicher.
Das obige ist der detaillierte Inhalt vonWie löst man den MySQL-Fehler „Angegebener Schlüssel zu lang; maximale Schlüssellänge beträgt 1000 Bytes'?. Für weitere Informationen folgen Sie bitte anderen verwandten Artikeln auf der PHP chinesischen Website!