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

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

Linda Hamilton
リリース: 2025-01-12 09:28:41
オリジナル
874 人が閲覧しました

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

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 サイトの他の関連記事を参照してください。

このウェブサイトの声明
この記事の内容はネチズンが自主的に寄稿したものであり、著作権は原著者に帰属します。このサイトは、それに相当する法的責任を負いません。盗作または侵害の疑いのあるコンテンツを見つけた場合は、admin@php.cn までご連絡ください。
著者別の最新記事
人気のチュートリアル
詳細>
最新のダウンロード
詳細>
ウェブエフェクト
公式サイト
サイト素材
フロントエンドテンプレート