Laravel: 고유한 유효성 검사 규칙을 사용하여 모델 업데이트
Laravel에서 모델 업데이트 중 필드 유효성을 검사하는 것은 데이터 무결성을 보장하는 데 중요합니다. 그러나 고유한 유효성 검사 규칙은 기존 레코드를 업데이트할 때 문제를 일으킬 수 있습니다.
저장소 클래스에서 다음 코드를 고려하세요.
public function update($id, $data) {
$user = $this->findById($id);
$user->fill($data);
$this->validate($user->toArray());
$user->save();
return $user;
}
이 코드는 "사용자 이름" 및 "이메일"과 같은 고유 필드를 포함하여 모델 필드의 유효성을 다시 검사하려고 시도합니다. 그러나 이 접근 방식은 기존 고유 값으로 레코드를 업데이트하려고 할 때 유효성 검사 오류가 발생할 수 있습니다.
이 문제를 해결하려면 고유 제약 조건을 위반하지 않고 업데이트를 허용하도록 유효성 검사에서 현재 레코드를 제외해야 합니다. 업데이트되는 인스턴스의 ID를 유효성 검사기에 추가하여 이를 달성할 수 있습니다. 방법은 다음과 같습니다.
인스턴스 ID를 전달합니다.
업데이트 방법에 업데이트되는 인스턴스 ID를 전달합니다.
public function update($id, $data) {
$user = $this->findById($id);
$user->fill($data);
$this->validate($user->toArray(), ['id' => $id]);
$user->save();
}
검증에서 현재 레코드를 제외합니다.
검증기에서는 id 매개변수를 사용하여 리소스를 업데이트하는지 아니면 생성하는지 감지합니다.
업데이트 중: 고유한 확인 규칙의 경우 현재 레코드를 제외하려면 규칙에 ,{$id}를 추가하세요. 예:
'email' => 'unique:users,email,{$id}',
만들기: 고유한 유효성 검사 규칙의 경우 ID를 포함하지 마세요. 예:
'email' => 'unique:users,email',
다음 단계에 따라 다음을 수행할 수 있습니다. 고유한 유효성 검사 제약 조건을 준수하면서 Laravel 모델을 우아하게 업데이트하세요.
부인 성명: 제공된 모든 리소스는 부분적으로 인터넷에서 가져온 것입니다. 귀하의 저작권이나 기타 권리 및 이익이 침해된 경우 자세한 이유를 설명하고 저작권 또는 권리 및 이익에 대한 증거를 제공한 후 이메일([email protected])로 보내주십시오. 최대한 빨리 처리해 드리겠습니다.
Copyright© 2022 湘ICP备2022001581号-3