>백엔드 개발 >PHP 튜토리얼 >Laravel Eloquent에서 여러 OR 및 AND 조건을 사용하여 복잡한 쿼리를 구성하는 방법은 무엇입니까?

Laravel Eloquent에서 여러 OR 및 AND 조건을 사용하여 복잡한 쿼리를 구성하는 방법은 무엇입니까?

Barbara Streisand
Barbara Streisand원래의
2024-11-27 01:18:11824검색

How to Construct Complex Queries with Multiple OR and AND Conditions in Laravel Eloquent?

Laravel Eloquent에서 여러 OR 및 AND 조건을 사용하여 쿼리

Laravel Eloquent에서 여러 OR 및 AND 조건이 포함된 복잡한 쿼리를 구성하려면 때때로 필요할 수 있습니다. 신중하게 고려하세요.

OR로 쿼리하고 AND

Eloquent를 사용하여 다음 SQL 문을 표현하려면:

WHERE (a = 1 OR b =1 ) AND (c = 1 OR d = 1)

Laravel 7.x/4.2에 도입된 논리적 그룹화를 활용하세요:

Model::where(function ($query) {
    $query->where('a', '=', 1)
          ->orWhere('b', '=', 1);
})
->where(function ($query) {
    $query->where('c', '=', 1)
          ->orWhere('d', '=', 1);
});

이 예에서 쿼리는 두 개의 개별 논리 그룹을 조인합니다. 여기서 각 그룹은 해당 열 집합에 OR 조건을 적용합니다. 그런 다음 이러한 논리 그룹은 AND 조건을 사용하여 결합됩니다.

복잡한 쿼리에 원시 SQL 사용

더욱 복잡한 쿼리의 경우 원시 SQL을 사용해야 할 수도 있습니다. 이는 DB::raw() 메소드를 사용하여 수행할 수 있습니다. 예를 들어, 원시 SQL을 사용하여 위와 동일한 쿼리를 실행하려면:

$query = "SELECT * FROM table_name WHERE (a = 1 OR b = 1) AND (c = 1 OR d = 1)";
$results = DB::select(DB::raw($query));

원시 SQL을 사용하면 Eloquent의 쿼리 빌더 보호를 우회할 수 있으며 잠재적인 보안 취약성을 초래할 수 있으므로 주의해서 사용해야 합니다. .

위 내용은 Laravel Eloquent에서 여러 OR 및 AND 조건을 사용하여 복잡한 쿼리를 구성하는 방법은 무엇입니까?의 상세 내용입니다. 자세한 내용은 PHP 중국어 웹사이트의 기타 관련 기사를 참조하세요!

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