"일꾼이 일을 잘하려면 먼저 도구를 갈고 닦아야 한다." - 공자, 『논어』.
첫 장 > 프로그램 작성 > Laravel에서 eloquent를 사용하는 방법

Laravel에서 eloquent를 사용하는 방법

2024-07-31에 게시됨
검색:899

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"를 작성하는 더 멋진 방법일 뿐만 아니라 조건부 쿼리를 구성하는 좋은 방법이기도 합니다.

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

릴리스 선언문 이 글은 https://dev.to/rohiturane/how-to-use-eloquent-when-in-laravel-3b6b?1 에서 복제되었습니다.1 침해 내용이 있는 경우, [email protected]으로 연락하여 삭제하시기 바랍니다.
최신 튜토리얼 더>

부인 성명: 제공된 모든 리소스는 부분적으로 인터넷에서 가져온 것입니다. 귀하의 저작권이나 기타 권리 및 이익이 침해된 경우 자세한 이유를 설명하고 저작권 또는 권리 및 이익에 대한 증거를 제공한 후 이메일([email protected])로 보내주십시오. 최대한 빨리 처리해 드리겠습니다.

Copyright© 2022 湘ICP备2022001581号-3