> 백엔드 개발 > PHP 튜토리얼 > ## Laravel에서 오류 없이 고유한 검증 규칙을 사용하여 모델을 업데이트하는 방법은 무엇입니까?

## Laravel에서 오류 없이 고유한 검증 규칙을 사용하여 모델을 업데이트하는 방법은 무엇입니까?

Patricia Arquette
풀어 주다: 2024-10-25 07:32:28
원래의
641명이 탐색했습니다.

## How to Update Models with Unique Validation Rules in Laravel Without Errors?

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."]}
로그인 후 복사

해결책: 현재 인스턴스에 대한 고유 규칙 무시

이 문제를 우아하게 해결하려면 업데이트 중인 현재 인스턴스에 대해 고유한 유효성 검사 규칙을 무시할 수 있습니다.

  1. 인스턴스 ID를 유효성 검사기에 전달하세요.

    저장소 메소드에서 업데이트되는 인스턴스의 ID를 유효성 검사 메소드에 전달합니다.

  2. 검증기에서 매개변수를 사용하여 생성 및 업데이트:

    유효성 검사 규칙에서 작업이 업데이트인지 생성인지 나타내는 매개변수를 추가합니다.

업데이트 규칙 :

현재 ID를 무시하도록 고유 규칙을 강제합니다.

'email' => 'unique:users,email_address,' . $userId,
로그인 후 복사

생성 규칙:

평소와 같이 진행합니다. 고유 규칙:

'email' => 'unique:users,email_address',
로그인 후 복사

이러한 변경 사항을 통합하면 기존 기록의 업데이트를 방해하지 않고 고유한 확인 규칙을 시행할 수 있습니다.

위 내용은 ## Laravel에서 오류 없이 고유한 검증 규칙을 사용하여 모델을 업데이트하는 방법은 무엇입니까?의 상세 내용입니다. 자세한 내용은 PHP 중국어 웹사이트의 기타 관련 기사를 참조하세요!

원천:php.cn
본 웹사이트의 성명
본 글의 내용은 네티즌들의 자발적인 기여로 작성되었으며, 저작권은 원저작자에게 있습니다. 본 사이트는 이에 상응하는 법적 책임을 지지 않습니다. 표절이나 침해가 의심되는 콘텐츠를 발견한 경우 admin@php.cn으로 문의하세요.
저자별 최신 기사
인기 튜토리얼
더>
최신 다운로드
더>
웹 효과
웹사이트 소스 코드
웹사이트 자료
프론트엔드 템플릿