ホームページ >データベース >mysql チュートリアル >Laravelのクエリビルダーを使用してサブクエリから効率的に選択するにはどうすればよいですか?

Laravelのクエリビルダーを使用してサブクエリから効率的に選択するにはどうすればよいですか?

Linda Hamilton
Linda Hamiltonオリジナル
2025-01-12 09:28:41786ブラウズ

How Can I Efficiently Select from Subqueries Using Laravel's Query Builder?

Laravel クエリビルダーはサブクエリを効率的に処理します

Eloquent ORM を使用してサブクエリからデータを取得する場合、開発者は多くの場合、toSql() とネイティブ クエリを組み合わせて使用​​します。このアプローチは機能しますが、十分に直観的ではありません。より効率的なソリューションがここに提供されています:

たとえば、次のサブクエリから結果の数を抽出するには:

<code class="language-sql">SELECT COUNT(*) 
FROM (
  SELECT * 
  FROM abc 
  GROUP BY col1
) AS a;</code>

Laravel では、mergeBindings を使用してネイティブ クエリを Eloquent クエリにマージできます。まず、サブクエリ用の Eloquent Builder インスタンスを作成します:

<code class="language-php">$sub = Abc::where(..)->groupBy(..);</code>

次に、DB::table を使用してサブクエリを参照する新しいテーブルを作成し、対応するバインディングを手動で設定します。

<code class="language-php">$count = DB::table( DB::raw("({$sub->toSql()}) as sub") )
    ->mergeBindings($sub->getQuery()) // 获取底层查询构造器
    ->count();</code>
このアプローチにより、マージされたクエリに正しいバインディングが適用され、手動の文字列操作を必要とせずに必要な結果が得られます。

以上がLaravelのクエリビルダーを使用してサブクエリから効率的に選択するにはどうすればよいですか?の詳細内容です。詳細については、PHP 中国語 Web サイトの他の関連記事を参照してください。

声明:
この記事の内容はネチズンが自主的に寄稿したものであり、著作権は原著者に帰属します。このサイトは、それに相当する法的責任を負いません。盗作または侵害の疑いのあるコンテンツを見つけた場合は、admin@php.cn までご連絡ください。