Development Tip

Laravel Advanced 함수에 변수를 전달하는 방법은 어디입니까?

yourdevel 2020. 11. 9. 21:17
반응형

Laravel Advanced 함수에 변수를 전달하는 방법은 어디입니까?


문서의 예 :

DB::table('users')
        ->whereExists(function($query)
        {
            $query->select(DB::raw(1))
                  ->from('orders')
                  ->whereRaw('orders.user_id = users.id');
        })
        ->get();

하지만 다음과 같은 외부 변수를 사용해야하는 경우 :

            ->where('city_id', '=', $this->city->id)
            ->where(function($query)
                {
                    $query->where('name', 'LIKE', '%'.$searchQuery.'%')
                    ->orWhere('address', 'LIKE', '%'.$searchQuery.'%')

                })

지금은 새 속성을 만들고을 통해 액세스 $this->했지만 더 편리한 방법이 있습니까?


use키워드 를 사용하여 부모 범위에서 클로저로 필요한 변수를 전달할 수 있습니다 .

예를 들면 :

DB::table('users')->where(function ($query) use ($activated) {
    $query->where('activated', '=', $activated);
})->get();

자세한 내용은 여기 에서 확인 하세요 .


@kajetons의 대답은 완전히 작동합니다.

다음과 같이 전달하여 여러 변수를 전달할 수도 있습니다. use($var1, $var2)

DB::table('users')->where(function ($query) use ($activated,$var2) {
    $query->where('activated', '=', $activated);
    $query->where('var2', '>', $var2);
})->get();

Laravel eloquent를 사용한다면 이것도 시도해 볼 수 있습니다.

$result = self::select('*')
                    ->with('user')
                    ->where('subscriptionPlan', function($query) use($activated){
                        $query->where('activated', '=', $roleId);
                    })
                    ->get();

이것을 사용하여 변수를 전달할 수 있습니다 ...

$status =1;
 $info = JOBS::where(function($query) use ($status){        
         $query->where('status',$status);
         })->get();
print_r($info);

참고 URL : https://stackoverflow.com/questions/29548073/laravel-advanced-wheres-how-to-pass-variable-into-function

반응형