【laravel】バリデーションのユニークチェックの書き方わかりにくい問題
はじめに
タイトルにもある通り、laravelのReqestファイルに記載したバリデーションでユニークバリデーションの記述が異様にわかりづらかったのでメモとして残します。
解読対象
return [
'login_id', 'unique:users,login_id,NULL,id,deleted_at,NULL',
];
return [
'login_id', 'unique:users,login_id,NULL,id,deleted_at,NULL',
];
他のバリデーション指示はあんなにシンプルなのにどうしてユニークだけこんなにわかりづらいんだろう、、、理解にすこし時間がかかってしまいました。
内容解説
左から順に
対象カラム名:
unique:ユニーク
users:テーブル名
login_id:チェックするカラム
NULL:除外する値
id:除外する列
deleted_at:追加でユニークチェックを行うカラム
NULL:追加でユニークチェックを行うカラムの条件値
となります。
・除外する値と列二つを組み合わると、今回はidがNULLなレコードはユニークチェックの対象外となります。
・追加でユニークチェックを行うカラムの条件値は該当するレコードに対してユニークチェックを行うので、今回はdeleted_atカラムのレコード内容がNULLのものを対象に追加でユニークチェックを行います。
おわりに
多分わかりづらかった理由は除外と追加が同じように書くので混乱の原因になったと思います。
補足で、今回は除外する値をNULLにしていますが、${id}のような形にしておくとこれから更新するデータは除外してくれます。
また、deleted_atカラムのレコード内容がNULLのものを対象にする事で、ソフトデリートしたレコードをユニークチェックに引っかからないようにできます。
Author And Source
この問題について(【laravel】バリデーションのユニークチェックの書き方わかりにくい問題), 我々は、より多くの情報をここで見つけました https://qiita.com/ka8210/items/b759c2f298475b89fe54著者帰属:元の著者の情報は、元のURLに含まれています。著作権は原作者に属する。
Content is automatically searched and collected through network algorithms . If there is a violation . Please contact us . We will adjust (correct author information ,or delete content ) as soon as possible .