ドキュメントの例:
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);