ホームページ >データベース >mysql チュートリアル >Laravelのクエリビルダーを使用してサブクエリから効率的に選択するにはどうすればよいですか?
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 サイトの他の関連記事を参照してください。