Heim > Datenbank > MySQL-Tutorial > Wie behebt man den Fehler „Laravel-Migration: Eindeutiger Schlüssel ist zu lang'?

Wie behebt man den Fehler „Laravel-Migration: Eindeutiger Schlüssel ist zu lang'?

Linda Hamilton
Freigeben: 2024-12-15 15:55:11
Original
249 Leute haben es durchsucht

How to Fix the

Behebung des Problems „Laravel-Migration: Eindeutiger Schlüssel ist zu lang“

Beim Migrieren einer Laravel-Benutzertabelle können Entwickler auf einen Fehler stoßen, der darauf hinweist dass der angegebene eindeutige Schlüssel zu lang ist. Trotz der expliziten Angabe eines zweiten Parameters in der Methode unique(), wie in einem Laravel-Problemthread vorgeschlagen, bleibt der Fehler bestehen.

Das zugrunde liegende Problem dreht sich um die Länge der E-Mail-Spalte. Die Standardlänge von Laravel für Zeichenfolgenspalten beträgt 255 Zeichen, was für E-Mail-Adressen möglicherweise nicht ausreicht.

Lösung

Um dieses Problem zu beheben, geben Sie eine kleinere Länge für die E-Mail-Spalte an . Die empfohlene Standardlänge beträgt 250 Zeichen:

$table->string('email', 250);
Nach dem Login kopieren

Es ist jedoch erwähnenswert, dass dieses Problem in Laravel 5.4 behoben wurde. So wenden Sie eine Lösung für diese Version an:

Für Laravel 5.4 und höher

  1. Bearbeiten Sie die Datei AppServiceProvider.php.
  2. Fügen Sie den folgenden Code zum boot() hinzu Methode:
use Illuminate\Database\Schema\Builder;

public function boot()
{
    Builder::defaultStringLength(191);
}
Nach dem Login kopieren

Dies legt eine Standard-String-Länge von 191 Zeichen für String-Spalten fest, wodurch die Notwendigkeit entfällt, Spaltenlängen manuell anzugeben.

Das obige ist der detaillierte Inhalt vonWie behebt man den Fehler „Laravel-Migration: Eindeutiger Schlüssel ist 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