2016-03-30 13 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 | 
+----+--------------+-----------+----------+ 

作品:

私のテーブルは次のようになります。しかし、私が更新しようとしている現在の場所を除外するための検証ルールを設定する方法がわかりません - '名前'列をチェックする必要があります。

私はこれがうまくいくと期待していましたが、そうではありません。

私は働く、 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');  

    } 

答えて

0

あなたは、カスタマーの検証を作成し、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, 
関連する問題