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 중국어 웹사이트의 기타 관련 기사를 참조하세요!