Laravel: 関連モデルの数による関係の順序付け
Laravel では、関連モデルの数に基づいてレコードを順序付けする必要が生じる場合があります。 。この手法は、データベース内で最も人気のある項目をランク付けしたり特定したりする場合に特に役立ちます。
質問に示されている例を考えてみましょう。ここでは、関連する参加者の数に基づいて最も人気のあるハッカソンを取得したいとします。 。これを実現するには、Laravel の Eloquent ORM の withCount() メソッドと orderBy() メソッドを利用できます。
withCount() メソッド動的カウントをベース クエリに追加すると、関連モデルのカウントをメイン クエリに直接含めることができます。あなたの場合、これは次のようになります:
$hackathons = Hackathon::withCount('participants');
基本クエリにカウントを含めたら、orderBy() メソッドを使用して、カウントに基づいてレコードを並べ替えることができます。 :
$hackathons = $hackathons->orderBy('participants_count', 'desc');
最後に、で提供されている解決策に示すように、ページネーションを使用して結果を表示できます。 response:
$hackathons = $hackathons->paginate(10);
このアプローチにより、参加者の数に基づいてハッカソンが順序付けされるため、最も人気のあるハッカソンを効率的に取得できます。
以上が関連するモデル数に基づいて Laravel 関係を並べ替えるにはどうすればよいですか?の詳細内容です。詳細については、PHP 中国語 Web サイトの他の関連記事を参照してください。