ホームページ >PHPフレームワーク >Laravel >laravelが一意であるかどうかを確認する方法

laravelが一意であるかどうかを確認する方法

PHPz
PHPzオリジナル
2023-04-23 09:14:471258ブラウズ

Laravel フレームワークでは、入力データの一意性を検証することが一般的な要件です。たとえば、ユーザーの電子メールまたは携帯電話番号を確認して、それらが繰り返し登録されないようにします。

Laravel は非常に便利な独自の検証ルールを提供します。フォームを送信するときに、ルールに unique:table,column を追加するだけです。例:

'username' => 'required|unique:users,username|max:255',
'email' => 'required|unique:users,email|max:255|email',

上記のコードでは、一意のルールは一意性検証テーブルの users とフィールドの username または email を指定します。これにより、他のユーザーが同じユーザー名または電子メールを使用しないことが保証されます。

しかし、実際のアプリケーションでは、独自のルールではニーズを完全に満たすことはできません。たとえば、データを更新すると、更新対象の値がデータベースにすでに存在するため、元の一意性検証ルールによってエラーが報告される場合があります。

この問題を解決するために、Laravel は追加のパラメーター exclude を提供します。例:

'username' => 'required|unique:users,username,' . $userId . ',id|max:255',

上記のコードでは、$userId は更新される現在のユーザー ID を表します。一意のルールで exclude パラメーターを使用することで、一意性を検証するときに現在のユーザーを除外するように Laravel に指示します。

exclude パラメータに加えて、Laravel は他のカラムの条件を指定する other_columns パラメータも提供します。例:

'username' => Rule::unique('users')
    ->where(function ($query) use ($other_column_value) {
        return $query->where('other_column', $other_column_value);
    })
    ->ignore($userId),

上記のコードでは、Rule クラスと where メソッドを使用して他の列の条件を定義し、一意性検証が指定された条件によってのみ制限されるようにしています。 ignore メソッドは、現在のユーザーを除外するためにも使用されます。

要約すると、Laravel で一意性を検証するときは、次の問題に注意する必要があります。

  1. 一意のルールで exclude パラメーターを使用して、現在のデータの影響を除外します。
  2. Rule クラスと where メソッドを使用して他の列の条件を定義し、一意性の検証が他の列の影響を受けないようにすることができます。

上記の手法を使用すると、データの一意性をより柔軟に検証し、データの整合性と正確性を保証できます。

以上がlaravelが一意であるかどうかを確認する方法の詳細内容です。詳細については、PHP 中国語 Web サイトの他の関連記事を参照してください。

声明:
この記事の内容はネチズンが自主的に寄稿したものであり、著作権は原著者に帰属します。このサイトは、それに相当する法的責任を負いません。盗作または侵害の疑いのあるコンテンツを見つけた場合は、admin@php.cn までご連絡ください。