Heim > Datenbank > MySQL-Tutorial > Wie löst man den MySQL-Fehler „Angegebener Schlüssel zu lang; maximale Schlüssellänge beträgt 1000 Bytes'?

Wie löst man den MySQL-Fehler „Angegebener Schlüssel zu lang; maximale Schlüssellänge beträgt 1000 Bytes'?

Barbara Streisand
Freigeben: 2024-12-10 22:34:16
Original
623 Leute haben es durchsucht

How to Solve MySQL's

MySQL-Fehler: „Angegebener Schlüssel zu lang; maximale Schlüssellänge beträgt 1000 Bytes“

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

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

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!

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