Laravel: 고유한 유효성 검사 규칙으로 모델 업데이트
Laravel에서 모델을 업데이트할 때 유효성 검사를 통해 데이터 무결성을 보장하는 것이 중요합니다. 그러나 사용자 이름 및 이메일과 같은 속성에 대한 고유한 유효성 검사 규칙은 문제를 일으킬 수 있습니다.
문제 설명
사용자 이름과 이메일에 고유한 유효성 검사 규칙이 있는 가상의 사용자 모델에서, 저장소를 사용하여 레코드를 업데이트하면 유효성 검사 오류가 발생할 수 있습니다.
public function update($id, $data) { $user = $this->findById($id); $user->fill($data); $this->validate($user->toArray()); $user->save(); return $user; }
테스트 실패, 반환:
ValidationException: {"username":["The username has already been taken."],"email":["The email has already been taken."]}
해결책: 현재 인스턴스에 대한 고유 규칙 무시
이 문제를 우아하게 해결하려면 업데이트 중인 현재 인스턴스에 대해 고유한 유효성 검사 규칙을 무시할 수 있습니다.
인스턴스 ID를 유효성 검사기에 전달하세요.
저장소 메소드에서 업데이트되는 인스턴스의 ID를 유효성 검사 메소드에 전달합니다.
검증기에서 매개변수를 사용하여 생성 및 업데이트:
유효성 검사 규칙에서 작업이 업데이트인지 생성인지 나타내는 매개변수를 추가합니다.
업데이트 규칙 :
현재 ID를 무시하도록 고유 규칙을 강제합니다.
'email' => 'unique:users,email_address,' . $userId,
생성 규칙:
평소와 같이 진행합니다. 고유 규칙:
'email' => 'unique:users,email_address',
이러한 변경 사항을 통합하면 기존 기록의 업데이트를 방해하지 않고 고유한 확인 규칙을 시행할 수 있습니다.
위 내용은 ## Laravel에서 오류 없이 고유한 검증 규칙을 사용하여 모델을 업데이트하는 방법은 무엇입니까?의 상세 내용입니다. 자세한 내용은 PHP 중국어 웹사이트의 기타 관련 기사를 참조하세요!