Heim > Datenbank > MySQL-Tutorial > Warum ist mein MySQL Unique Index zu lang und wie kann ich das Problem beheben?

Warum ist mein MySQL Unique Index zu lang und wie kann ich das Problem beheben?

Mary-Kate Olsen
Freigeben: 2024-12-13 15:43:10
Original
249 Leute haben es durchsucht

Why Is My MySQL Unique Index Too Long, and How Can I Fix It?

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

  • Reduzieren VARCHAR-Feldgröße: Durch Verringern der Größe der VARCHAR-Felder kann sich der Gesamtschlüssel verringern Länge.
  • Partitionieren Sie den Index: Erstellen Sie eine Teilmenge der zu indizierenden Spalte, wie im Beispiel gezeigt:
ALTER TABLE `mytable` ADD UNIQUE ( column1(15), column2(200) );
Nach dem Login kopieren
  • Datenmodell überprüfen: Es kann von Vorteil sein, das Datenmodell zu überprüfen, um Geschäftsregeln zu implementieren, ohne die von MySQL zu überschreiten Einschränkungen.

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!

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