Heim > Datenbank > MySQL-Tutorial > Warum gibt meine Datenbank den Fehler „Ungültige Indexschlüsselspalte' aus und wie kann ich ihn beheben?

Warum gibt meine Datenbank den Fehler „Ungültige Indexschlüsselspalte' aus und wie kann ich ihn beheben?

Linda Hamilton
Freigeben: 2024-12-18 15:32:11
Original
844 Leute haben es durchsucht

Why Does My Database Throw an

Ungültige Indexschlüsselspalte: Den Fehler verstehen und beheben

Die Fehlermeldung „Spalte ‚Schlüssel‘ in Tabelle ‚misc_info‘ ist von a „Typ, der für die Verwendung als Schlüsselspalte in einem Index ungültig ist“ weist auf ein Problem mit dem Datentyp einer Spalte hin, die als Schlüssel in einem Index verwendet wird. Während eine schnelle Suche zeigt, dass die Indexlängenbeschränkung 450 Zeichen beträgt, bietet dies allein keine Lösung für den Fehler.

In diesem Fall bezieht sich der Fehler auf eine Spalte namens „key“ mit dem Datentyp nvarchar(max). Um dieses Problem zu beheben, muss der Datentyp der Schlüsselspalte in einen gültigen Typ für einen Indexschlüssel geändert werden. Eindeutige Einschränkungen für Indexschlüssel haben eine maximale Größenbeschränkung von 8000 Bytes pro Zeile, wobei nur die ersten 900 Bytes genutzt werden. Um maximale Kompatibilität zu gewährleisten und potenzielle Fehler zu vermeiden, sollte die Schlüsselspalte daher einen Datentyp haben, der eine maximale Länge von 450 Zeichen zulässt.

Die folgende überarbeitete SQL-Anweisung behebt den Fehler durch Änderung des Datentyps der Schlüsselspalte zu nvarchar(450):

CREATE TABLE [misc_info] (
    [id] INTEGER PRIMARY KEY IDENTITY NOT NULL,
    [key] NVARCHAR(450) UNIQUE NOT NULL,
    [value] NVARCHAR(MAX) NOT NULL
);
Nach dem Login kopieren

Durch die Verwendung von nvarchar(450) für die Schlüsselspalte können Sie einen eindeutigen Index erstellen, ohne auf das zu stoßen Fehler „Ungültiger Typ für Schlüsselspalte“. Beachten Sie, dass Sie, wenn möglich, die Schlüsselspaltenlänge auf 900 Zeichen erhöhen können, wenn Sie varchar anstelle von nvarchar verwenden.

Das obige ist der detaillierte Inhalt vonWarum gibt meine Datenbank den Fehler „Ungültige Indexschlüsselspalte' aus und wie kann ich ihn 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