Heim >Backend-Entwicklung >PHP-Tutorial >Wie erzwinge ich eine eindeutige Validierung über mehrere Spalten in Laravel?
Laravel: Erreichen einer eindeutigen Validierung über mehrere Tabellenspalten hinweg
Für Szenarien, in denen Sie eine Datenbank mit Tabellen haben, die mehrere Spalten enthalten, deren Kombination eindeutig bleiben muss , wird es notwendig, diese Eindeutigkeitsbeschränkung in Ihrer Laravel-Anwendung durchzusetzen.
Ein solches Beispiel ist eine „Server“-Tabelle mit den Spalten „IP“ und „Hostname“. Sie möchten sicherstellen, dass eine Kombination aus einer bestimmten „IP“ und einem „Hostnamen“ eindeutig ist, auch wenn einzelne Werte für „IP“ oder „Hostname“ möglicherweise mehrmals vorkommen.
Lösung mit Regel:: unique()
Um diese Validierung zu implementieren, verwenden Sie die Methode Rule::unique. Mit dieser Methode können Sie benutzerdefinierte eindeutige Regeln für einen bestimmten Satz von Spalten festlegen. Hier ist ein Beispiel:
<code class="php">$messages = [ 'data.ip.unique' => 'Given ip and hostname are not unique', ]; Validator::make($data, [ 'data.ip' => [ 'required', Rule::unique('servers') ->where(function ($query) use ($ip, $hostname) { return $query->where('ip', $ip) ->where('hostname', $hostname); }), ], ], $messages);</code>
Erklärung
Durch die Implementierung dieser Regel stellen Sie effektiv sicher, dass Ihre Anwendung doppelte Kombinationen von „IP“ und „Hostname“ in der Tabelle „Server“ nicht zulässt.
Das obige ist der detaillierte Inhalt vonWie erzwinge ich eine eindeutige Validierung über mehrere Spalten in Laravel?. Für weitere Informationen folgen Sie bitte anderen verwandten Artikeln auf der PHP chinesischen Website!