>백엔드 개발 >PHP 튜토리얼 >Laravel의 여러 열에서 고유성을 확인하는 방법은 무엇입니까?

Laravel의 여러 열에서 고유성을 확인하는 방법은 무엇입니까?

Linda Hamilton
Linda Hamilton원래의
2024-11-01 12:18:30879검색

How to Validate Uniqueness Across Multiple Columns in Laravel?

Laravel에서 여러 열의 고유성 유효성 검사

Laravel에서 데이터의 유효성을 검사할 때 중복 항목을 방지하기 위해 여러 열에서 고유성을 확인하는 것이 중요합니다. 이는 IP와 호스트 이름 열 모두 고유성을 고려해야 하는 경우와 같이 여러 값 조합이 고유해야 하는 시나리오에 특히 적합합니다.

여러 열에 대한 고유 유효성 검사

여러 열의 고유성을 검증하기 위해 Laravel은 Rule::unique 규칙을 제공합니다. 이 규칙을 사용하면 검증 중에 고려할 테이블과 열을 지정할 수 있습니다.

사용자 정의 검증 규칙

주어진 시나리오에서 목표는 다음을 고려하여 IP 필드를 검증하는 것입니다. ip 및 호스트 이름 열 모두. 이를 달성하려면 다음과 같은 사용자 정의 규칙을 사용할 수 있습니다.

<code class="php">use Illuminate\Validation\Rule;

$data = [
    'ip' => '192.168.0.1',
    'hostname' => 'server-1',
];

$messages = [
    'data.ip.unique' => 'Given ip and hostname are not unique',
];

Validator::make($data, [
    'ip' => [
        'required',
        Rule::unique('servers')
            ->where(function ($query) use ($ip, $hostname) {
                return $query->where('ip', $ip)->where('hostname', $hostname);
            }),
    ],
], $messages);

if ($validator->fails()) {
    // Handle validation errors...
}</code>

설명

  • 규칙::unique 규칙은 서버 테이블을 지정합니다. 여기에는 ip 및 호스트 이름 열이 포함됩니다.
  • 규칙 내의 where 클로저는 고유성을 위해 충족되어야 하는 조건을 정의합니다. 이 경우 IP와 호스트 이름이 모두 데이터베이스의 기존 레코드와 일치하는지 확인합니다.
  • 지정된 IP와 호스트 이름이 고유하지 않은 사용자 정의 오류 메시지는 data.ip.unique 유효성 검사 규칙과 연결되어 있습니다.

결론

사용자 지정 where 조건과 함께 Rule::unique 규칙을 활용하면 Laravel의 여러 열에 걸쳐 고유성을 효과적으로 보장할 수 있습니다. 이 접근 방식을 사용하면 특히 초기 쿼리에서 언급된 것과 같은 시나리오를 고려할 때 더욱 구체적이고 유연한 데이터 검증이 가능합니다.

위 내용은 Laravel의 여러 열에서 고유성을 확인하는 방법은 무엇입니까?의 상세 내용입니다. 자세한 내용은 PHP 중국어 웹사이트의 기타 관련 기사를 참조하세요!

성명:
본 글의 내용은 네티즌들의 자발적인 기여로 작성되었으며, 저작권은 원저작자에게 있습니다. 본 사이트는 이에 상응하는 법적 책임을 지지 않습니다. 표절이나 침해가 의심되는 콘텐츠를 발견한 경우 admin@php.cn으로 문의하세요.