[laravel] Eloquent Collection : 계산 및 비우기 감지

이것은 사소한 질문 일지 모르지만 Laravel이 반환 된 Eloquent 컬렉션 $result = Model::where(...)->get()이 비어 있는지 확인하고 요소 수를 계산 하는 특정 방법을 권장하는지 궁금합니다 .

우리는 현재 !$result빈 결과를 감지하는 데 사용하고 있습니까? 에 대해서는 count($result)실제로 빈 결과를 포함하여 모든 사례를 다루고 있습니까?



답변

사용하는 경우 ->get()를 단순히 아래 중 하나를 사용할 수 없습니다 :

if (empty($result)) { }
if (!$result) { }
if ($result) { }

결과가없는 경우에도 dd($result);인스턴스 Illuminate\Support\Collection가 항상 반환 된다는 것을 알 수 있습니다 . 본질적으로 확인하는 것은 $a = new stdClass; if ($a) { ... }항상 true를 반환합니다.

결과가 있는지 확인하려면 다음 중 하나를 수행하십시오.

if ($result->first()) { }
if (!$result->isEmpty()) { }
if ($result->count()) { }
if (count($result)) { }

쿼리 빌더 ->first()대신 대신 사용 ->get()하여 처음 찾은 모델의 인스턴스를 리턴 할 수도 있습니다 null. 데이터베이스에서 하나의 결과 만 필요하거나 예상 할 때 유용합니다.

$result = Model::where(...)->first();
if ($result) { ... }

참고 / 참조

보너스 정보

메소드 이름이 종종 둘 사이에서 동일하기 때문에 Collection과 Query Builder의 차이점은 Laravel의 새로운 사용자에게는 약간 혼동 될 수 있습니다. 따라서 어떤 작업을하고 있는지 아는 것이 혼란 스러울 수 있습니다. 쿼리 빌더는 기본적으로 쿼리를 실행하고 데이터베이스에 도달 할 메소드를 호출 할 때까지 (예 : 특정 메소드 등을 호출 할 때) 쿼리를 빌드합니다 ->all() ->first() ->lists(). 이러한 메소드 Collection 오브젝트 에도 존재하며 결과가 여러 개인 경우 쿼리 빌더에서 리턴 될 수 있습니다. 실제로 어떤 클래스를 사용하고 있는지 확실하지 않은 경우 수행 var_dump(User::all())하고 실험하여 실제로 어떤 클래스가 반환되는지 확인하십시오.get_class(...)). Collection 클래스의 소스 코드를 확인하는 것이 좋습니다. 매우 간단합니다. 그런 다음 Query Builder를 확인하고 함수 이름의 유사성을보고 실제로 데이터베이스에 도달하는시기를 찾으십시오.


답변

나는 당신이 찾고 있다고 생각합니다 :

$result->isEmpty()

와는 다르며 empty($result)결과는 빈 컬렉션이기 때문에 사실이 아닙니다. 당신의 제안 count($result)도 좋은 해결책입니다. 문서에서 참조를 찾을 수 없습니다


답변

위의 승인 된 답변에 동의합니다. 그러나 일반적으로 $results->isNotEmpty()아래 주어진 방법을 사용 합니다.

if($results->isNotEmpty())
{
//do something
}

if(!results->isEmpty())때때로 ‘!’를 추가하는 것을 잊었 기 때문에 보다 장황합니다 . 원하지 않는 오류가 발생할 수 있습니다.

이 방법은 버전 5.3 부터 존재합니다 .


답변

Laravel에는 결과 수 / 비어 있음 / 비어 없음을 확인하기위한 몇 가지 방법이 있습니다.

$result->isNotEmpty(); // True if result is not empty.
$result->isEmpty(); // True if result is empty.
$result->count(); // Return count of records in result.


답변

사용하는 것이 좋습니다

$result->isEmpty();

컬렉션이 비어 있으면 isEmpty 메소드는 true를 리턴합니다. 그렇지 않으면 false가 리턴됩니다.


답변

나는 당신이 같은 것을 시도 생각

  @if(!$result->isEmpty())
         // $result is not empty
    @else
        // $result is empty
    @endif

또는 사용

if (!$result) { }
if ($result) { } 


답변

넌 할 수있어

$result = Model::where(...)->count(); 

결과를 계산합니다.

당신은 또한 사용할 수 있습니다

if ($result->isEmpty()){}

결과가 비어 있는지 확인합니다.