Laravel에서 eloquent를 사용하는 방법

WBOY
풀어 주다: 2024-07-18 08:16:59
원래의
990명이 탐색했습니다.

Image description

이 글에서는 laravel eloquent when 조건을 구현하고 있습니다. 필터링 프로세스에서는 요청 시 if-else 조건을 사용합니다. 아래 코드를 확인해보세요.

if($request->filter_by == 'amount')
{
    $query->where('amount', '>', request('amount', 0));
}

if($request->filter_by == 'created_at')
{
    $query->orderBy('created_at', request('order', 'desc'));
}
로그인 후 복사

Laravel에서 eloquent를 사용하는 방법

when() 메소드를 사용할 수 있습니다. 더 읽기 쉽고 사용자 친화적입니다. 아래 코드를 확인해보세요.

$query = Order::query();

$query->when(request('filter_by') == 'amount', function($q){
    return $q->where('amount','>', request('amount',0));
});
$query->when(request('filter_by') == 'created_at', function($q){
    return $q->orderBy('created_at', request('order','desc'));
});

로그인 후 복사

When 메소드에 세 번째 인수를 전달할 수 있습니다. 이 클로저는 첫 번째 인수가 false로 평가되는 경우에만 실행됩니다.

$query = Order::query();
$query->when(request('filter_by') == 'amount', function($q){
    return $q->where('amount','>', request('amount',0));
}, function($q){
    return $q->orderBy('created_at', request('order','desc'));
})->get();
로그인 후 복사

동일한 "IF"를 작성하는 것이 더 보기 좋을 뿐만 아니라 조건부 쿼리를 정리하는 좋은 방법이기도 합니다.

이러한 유형의 기사에 대한 자세한 내용은 사이트에서 읽을 수 있습니다

위 내용은 Laravel에서 eloquent를 사용하는 방법의 상세 내용입니다. 자세한 내용은 PHP 중국어 웹사이트의 기타 관련 기사를 참조하세요!

원천:dev.to
본 웹사이트의 성명
본 글의 내용은 네티즌들의 자발적인 기여로 작성되었으며, 저작권은 원저작자에게 있습니다. 본 사이트는 이에 상응하는 법적 책임을 지지 않습니다. 표절이나 침해가 의심되는 콘텐츠를 발견한 경우 admin@php.cn으로 문의하세요.
인기 튜토리얼
더>
최신 다운로드
더>
웹 효과
웹사이트 소스 코드
웹사이트 자료
프론트엔드 템플릿