doc中的示例:
DB::table('users')
->whereExists(function($query)
{
$query->select(DB::raw(1))
->from('orders')
->whereRaw('orders.user_id = users.id');
})
->get();
Run Code Online (Sandbox Code Playgroud)
但是如果我需要像这样使用外部变量呢:
->where('city_id', '=', $this->city->id)
->where(function($query)
{
$query->where('name', 'LIKE', '%'.$searchQuery.'%')
->orWhere('address', 'LIKE', '%'.$searchQuery.'%')
})
Run Code Online (Sandbox Code Playgroud)
现在我创建了新属性并通过它访问了$this->,但还有更方便的方法吗?
kaj*_*ons 189
您可以使用use关键字将必要的变量从父作用域传递到闭包中.
例如:
DB::table('users')->where(function ($query) use ($activated) {
$query->where('activated', '=', $activated);
})->get();
Run Code Online (Sandbox Code Playgroud)
更多关于这一点.
Nag*_*aba 10
@kajetons的答案完全正常.
您还可以通过传递多个变量来传递它们: use($var1, $var2)
DB::table('users')->where(function ($query) use ($activated,$var2) {
$query->where('activated', '=', $activated);
$query->where('var2', '>', $var2);
})->get();
Run Code Online (Sandbox Code Playgroud)
如果你正在使用 Laravel eloquent 你也可以试试这个。
$result = self::select('*')
->with('user')
->where('subscriptionPlan', function($query) use($activated){
$query->where('activated', '=', $roleId);
})
->get();
Run Code Online (Sandbox Code Playgroud)
小智 6
您可以使用此传递变量...
$status =1;
$info = JOBS::where(function($query) use ($status){
$query->where('status',$status);
})->get();
print_r($info);
Run Code Online (Sandbox Code Playgroud)