2015-07-10 95 views
1

忽略獨特驗證我有當您創建具有unqiue phone_num這個customer模型。它在創建時可以正常工作,但是在我的更新函數中,這是一種基於id的自動填充值形式。如果用戶只按預期更新了address,則unique驗證將再次觸發The phone num has already been taken.如何處理此問題?我希望用戶能夠更新它忽略了unique驗證,如果phone_num仍從而使得如果用戶選擇改變phone_num上更新溫控功能Laravel 5

我的代碼unique驗證相同的信息:

public function update($id) 
{ 
    $rules = array(
     'title'    => 'required', 
     'firstname'   => 'required', 
     'lastname'   => 'required', 
     'gender'   => 'required', 
     'birthdate'   => 'required', 
     'age_bracket'  => 'required', 
     'addr1'    => 'required', 
     'addr2'    => 'required', 
     'addr3'    => 'required', 
     'addr4'    => 'required', 
     'town'    => 'required', 
     'country'   => 'required', 
     'postcode'   => 'required', 
     'phone_num'   => 'required|unique:customers', 
     'phone_type'  => 'required', 
     'work_status'  => 'required', 
     'home_status'  => 'required', 
     'marital_status' => 'required', 

    ); 

    $validator = Validator::make(Input::all(), $rules); 


    // Check if all fields is filled 
    if ($validator->fails()) 
    { 
     return Redirect::to('customer/'.$id.'/edit')->withErrors($validator); 
    } 
    else 
    { 
     $customer = Customer::find($id); 
     $customer->title   = Input::get('title'); 
     $customer->gender   = Input::get('gender'); 
     $customer->firstname  = Input::get('firstname'); 
     $customer->lastname  = Input::get('lastname'); 
     $customer->postcode  = Input::get('postcode'); 
     $customer->addr1   = Input::get('addr1'); 
     $customer->addr2   = Input::get('addr2'); 
     $customer->addr3   = Input::get('addr3'); 
     $customer->addr4   = Input::get('addr4'); 
     $customer->addr4   = Input::get('addr4'); 
     $customer->town   = Input::get('town'); 
     $customer->country   = Input::get('country'); 
     $customer->phone_num  = Input::get('phone_num'); 
     $customer->phone_type  = Input::get('phone_type'); 
     $customer->birthdate  = Input::get('birthdate'); 
     $customer->work_status  = Input::get('work_status'); 
     $customer->home_status  = Input::get('home_status'); 
     $customer->marital_status = Input::get('marital_status'); 
     $customer->agebracket  = Input::get('age_bracket'); 

     if($customer->save()) 
     { 
      Session::flash('alert-success', 'Form Submitted Successfully.'); 
     } 
     else 
     { 
      Session::flash('alert-danger', 'Error on submitting form.'); 
     } 

     return Redirect::to('customer/'.$id.'/edit'); 

    } 
} 

回答

8

unique規則需要一些額外的參數只是這個目的,它看起來像unique:table,column,except,idColumn

所以你的情況,except將是ididColumn將是您的ID列的名稱,可能是id

所以考慮到這一點,你會希望你的驗證規則是...

'required|unique:customers,phone_num,'.$id.',id' 
+0

哇!完美的作品!非常感謝! – jackhammer013

2

在L5.3 +你能流利使用規則門面處理。請注意, 驗證規則現在將成爲數組而不是使用|分隔符。 使用Illuminate \ Validation \ Rule;

Validator::make($data, [ 
    'email' => [ 
    'required', 
    Rule::unique('users')->ignore($user->id), 
    ], 
]);