2016-03-30 83 views
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');  

    } 

回答

0

您需要創建custome驗證和傳遞的ID陣列那要檢查如:

public function multipelvalidation() 
{ 
    Validator::extend('multipel', function ($attribute, $value) { 
     //check validation here and return true or false 
    }); 
} 

//... and use your rule in validation like below: 

'name' => 'required|multipel|max:255|unique:evac_routes,name,'.$this->name,