Laravel Advanced変数を関数に渡す方法はどこですか?


87

ドキュメントの例:

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->が、もっと便利な方法はありますか?

回答:


231

useキーワードを使用して、必要な変数を親スコープからクロージャーに渡すことができます。

例えば:

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

詳細はこちら

編集(2019更新):

PHP 7.4(2019年11月28日にリリース予定)では、矢印関数と呼ばれる無名関数の短いバリエーションが導入されており、これにより冗長性が少し低くなっています。

機能的にほぼ同等のPHP7.4を使用した例(以下の3番目の箇条書きを参照):

DB::table('users')->where(fn($query) => $query->where('activated', '=', $activated))->get();

通常の構文との違い:

  • fnの代わりにキーワードfunction
  • 親スコープからキャプチャする必要があるすべての変数を明示的にリストする必要はありません。これは、値によって自動的に行われるようになりました。use後者の例のキーワードの欠如を参照してください。
  • 矢印関数は常に値を返します。これは、void宣言時に戻り値の型を使用できないことも意味します。
  • returnキーワードをしなければならない省略すること。
  • 矢印関数には、returnステートメントである単一の式が必要です。現在、複数行機能はサポートされていません。ただし、メソッドをチェーンすることはできます。

15

@kajetonsの答えは完全に機能しています。

次のように渡すことで、複数の変数を渡すこともできます。 use($var1, $var2)

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

5

Laravelを雄弁に使用している場合は、これも試してみてください。

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

2

これを使用して変数を渡すことができます...

$status =1;
 $info = JOBS::where(function($query) use ($status){        
         $query->where('status',$status);
         })->get();
print_r($info);
弊社のサイトを使用することにより、あなたは弊社のクッキーポリシーおよびプライバシーポリシーを読み、理解したものとみなされます。
Licensed under cc by-sa 3.0 with attribution required.