web-dev-qa-db-fra.com

Laravel Advanced Wheres comment passer variable en fonction?

Exemple en doc:

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

Mais si je dois utiliser une variable externe comme celle-ci:

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

                })

Pour l'instant, j'ai créé une nouvelle propriété et y ai accédé via $this->, mais existe-t-il un moyen plus pratique?

57
frenzy

Vous pouvez passer les variables nécessaires de la portée parente dans la fermeture à l'aide du mot clé use.

Par exemple: 

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

Plus sur cela ici .

156
kajetons

La réponse de @kajetons est entièrement fonctionnelle.

Vous pouvez également transmettre plusieurs variables en les transmettant comme suit: use($var1, $var2)

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

Si vous utilisez Laravel éloquent, vous pouvez également essayer ceci.

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

Vous pouvez passer des variables en utilisant ceci ...

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