Laravel Advanced Wheres如何将变量传递给函数?

fre*_*nzy 71 php sql laravel

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)


Nik*_* K. 6

如果你正在使用 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)