Laravel クエリビルダーはサブクエリを効率的に処理します
Eloquent ORM を使用してサブクエリからデータを取得する場合、開発者は多くの場合、toSql()
とネイティブ クエリを組み合わせて使用します。このアプローチは機能しますが、十分に直観的ではありません。より効率的なソリューションがここに提供されています:
たとえば、次のサブクエリから結果の数を抽出するには:
SELECT COUNT(*) FROM ( SELECT * FROM abc GROUP BY col1 ) AS a;
Laravel では、mergeBindings
を使用してネイティブ クエリを Eloquent クエリにマージできます。まず、サブクエリ用の Eloquent Builder インスタンスを作成します:
$sub = Abc::where(..)->groupBy(..);
次に、DB::table
を使用してサブクエリを参照する新しいテーブルを作成し、対応するバインディングを手動で設定します。
$count = DB::table( DB::raw("({$sub->toSql()}) as sub") ) ->mergeBindings($sub->getQuery()) // 获取底层查询构造器 ->count();
以上がLaravelのクエリビルダーを使用してサブクエリから効率的に選択するにはどうすればよいですか?の詳細内容です。詳細については、PHP 中国語 Web サイトの他の関連記事を参照してください。