반응형
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);
반응형
'Development Tip' 카테고리의 다른 글
OS X 또는 iOS (Gestalt를 사용하지 않고)에서 런타임시 OS 버전을 어떻게 확인합니까? (0) | 2020.11.09 |
---|---|
콘솔 애플리케이션의 진행률 표시 줄 (0) | 2020.11.09 |
HTML에서 공백없이 긴 줄을 감싸는 방법은 무엇입니까? (0) | 2020.11.09 |
PHP 경고 : 알 수 없음 : 스트림을 열지 못했습니다. (0) | 2020.11.09 |
백본에서 상위 클래스에 액세스 (0) | 2020.11.09 |