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 |
+----+--------------+-----------+----------+
創建新的位置按預期工作。但我不知道如何設置驗證規則以排除我正在嘗試更新的當前位置 - 它需要根據「名稱」列進行檢查。
我希望像這樣的東西可以工作 - 但事實並非如此。
public function rules()
{
return [
'name' => 'required|max:255|unique:evac_routes,name,'.$this->name,
...
];
}
在我的控制,我使用Route::where('name', $route->name)->update
,它的工作原理,但我不能這個邏輯轉換爲驗證規則:
public function update($id, UpdateRouteRequest $request)
{
$route = Route::findOrFail($id);
$updateRows = Route::where('name', $route->name)->update([
'name' => $request->name,
...
]);
return redirect('routes');
}