2
ロケーション名を更新するときに、単一のIDだけでなく、テーブル内の複数の行に対してチェックを行う必要があります。期待通りに新しい場所を作成する複数の行に対してチェックする検証ルール
+----+--------------+-----------+----------+
| id | name | lat | lng |
+----+--------------+-----------+----------+
| 1 | Location One | 53.348333 | 0.348333 |
| 2 | Location One | 57.348222 | 0.348222 |
| 3 | Location One | 57.348111 | 0.545454 |
| 4 | Location Two | 55.348554 | 0.555444 |
| 5 | Location Two | 56.348667 | 0.348333 |
| 6 | Location Two | 56.348778 | 0.111111 |
+----+--------------+-----------+----------+
作品:
私のテーブルは次のようになります。しかし、私が更新しようとしている現在の場所を除外するための検証ルールを設定する方法がわかりません - '名前'列をチェックする必要があります。
私はこれがうまくいくと期待していましたが、そうではありません。
私は働く、Route::where('name', $route->name)->update
を使用していますが、私は検証ルールにこのロジックを変換することはできません私のコントローラで
public function rules()
{
return [
'name' => 'required|max:255|unique:evac_routes,name,'.$this->name,
...
];
}
:
public function update($id, UpdateRouteRequest $request)
{
$route = Route::findOrFail($id);
$updateRows = Route::where('name', $route->name)->update([
'name' => $request->name,
...
]);
return redirect('routes');
}