ホームページ >データベース >mysql チュートリアル >Laravelハッカソンを参加者数別に注文するにはどうすればよいですか?
Laravel: 関係数による順序付け
この場合、それぞれに関連付けられた参加者の数に基づいて並べ替えられたハッカソンを検索したいとします。提供されたテーブル構造とモデル定義により、明確なリレーショナル スキーマが得られます。
質問で述べたように、結果を取得する最初の試みにはいくつかの欠陥が含まれていました。まず、find を使用して関連モデルの数を取得することは、関係を熱心に読み込むため、大規模なデータセットの場合は非効率となる可能性があるため、お勧めできません。次に、クエリ内で参照されている $this->id は、ハッカソンの ID ではなく、クエリの作成に使用されたモデル インスタンスを参照しているため、正しくありません。
希望の順序付けを実現するには、Laravel を使用した次のアプローチを使用します。 5.3 の積極的な読み込みと名前付き関係を使用できます。
Hackathon::withCount('participants') ->orderBy('participants_count', 'desc') ->paginate(10);
withCount を使用すると、関連する参加者の数が積極的にロードされます。追加のデータベース クエリを行わずに効率的にカウントを取得します。次に、orderBy 句は、participants_count 属性に基づいて結果を降順に並べ替え、参加者の数に基づいて最も人気のあるハッカソンを効果的に提供します。
以上がLaravelハッカソンを参加者数別に注文するにはどうすればよいですか?の詳細内容です。詳細については、PHP 中国語 Web サイトの他の関連記事を参照してください。