답변:
사용하는 경우 ->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를 확인하고 함수 이름의 유사성을보고 실제로 데이터베이스에 도달하는시기를 찾으십시오.
Model::first()
실제로는 컬렉션이 아닌 쿼리 빌더의 '첫 번째'방법에 따라 작동하므로 데이터베이스에서 첫 번째 방법을 선택하지만 Model::get()
Illuminate \ Support 인스턴스를 반환합니다. \ 컬렉션은 그래서 당신이 그랬다면 $r = Model::get()
다음 $r->first()
은 해당 모음 내에서 첫 번째 항목을 선택합니다.
count($result)
작동 하는지 여부입니다 . 그 세부 사항을 추가하면 개선 될 것입니다.
foreach
루프를 사용 하여 컬렉션의 각 멤버를 반복 한 다음 이러한 검사 중 하나를 사용해야합니다 (생각 :) count($collection->column)
.
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가 리턴됩니다.
Laravel Documentation 에 따르면 다음과 같이 사용할 수 있습니다.
$result->isEmpty();
isEmpty
방법은 반환 true
컬렉션이 비어있는 경우; 그렇지 않으면 false
반환됩니다.
Laravel은 실제로 Model::all();
컬렉션을 원하지 않을 때 컬렉션을 반환 하므로 집합을 입력 할 수 있습니다.
(array)Model::all();
그런 다음 array_filter를 사용하여 결과를 반환 할 수 있습니다
$models = (array)Model::all()
$models = array_filter($models);
if(empty($models))
{
do something
}
이렇게하면 다음과 같은 작업을 수행 할 수 있습니다 count()
.
------ 해결 ------
이 경우 두 개의 cace에 대한 두 가지 유형의 카운트를 확인하려고합니다.
사례 1 :
결과에 단 하나의 레코드 만 포함 된 경우 다른 단어-> first ()를 사용하여 데이터베이스에서 단일 행을 선택하십시오.
if(count($result)){
...record is exist true...
}
사례 2 :
-> get () 또는-> all ()을 사용하여 결과에 여러 행의 다른 세트가 포함 된 경우
if($result->count()) {
...record is exist true...
}
first()
하면 결과가 다르다는 것을 추가하기 위해 빈 결과로get()
확인할 수 있습니다!$result
null