이것은 사소한 질문 일지 모르지만 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) { ... }
참고 / 참조
->first()
http://laravel.com/api/4.2/Illuminate/Database/Eloquent/Collection.html#method_firstisEmpty()
http://laravel.com/api/4.2/Illuminate/Database/Eloquent/Collection.html#method_isEmpty->count()
http://laravel.com/api/4.2/Illuminate/Database/Eloquent/Collection.html#method_countcount($result)
Collection이 Countable 및 내부count()
메소드를 구현하기 때문에 작동합니다 : http://laravel.com/api/4.2/Illuminate/Database/Eloquent/Collection.html#method_count
보너스 정보
메소드 이름이 종종 둘 사이에서 동일하기 때문에 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()){}
결과가 비어 있는지 확인합니다.