ホームページ >データベース >mysql チュートリアル >SQL の順序なしスコア テーブルからユーザー ランクを効率的に取得する方法
順序なしスコア テーブルからのランク取得
データ管理の分野では、スコアと関連情報をデータベース テーブルに保存するのが一般的です。 。ただし、テーブルが順序付けされていない場合、特に面倒なループを使用しない限り、ユーザーのランクを取得するのは困難になります。
たとえば、「id」、「install_id」などの列を持つ「スコア」テーブルを考えてみましょう。 「イニシャル」と「スコア」。ユーザーがランクをリクエストしたとき、そのスコア (たとえば 100) が 1000 人のプレイヤー中 100 位にランクされることを通知することを目的としています。
すべての行を反復してランクを決定する代わりに、次を使用するより効率的なアプローチがあります。 SQL ステートメント。 「rank」式内でサブクエリを利用すると、ユーザーのランクを直接取得できます。
<code class="sql">SELECT s1.initials, ( SELECT COUNT(*) FROM scores AS s2 WHERE s2.score > s1.score )+1 AS rank FROM scores AS s1</code>
このステートメントは、まずターゲット ユーザー (「s1」) の行を識別します。次に、サブクエリは、スコアがターゲット ユーザーのスコアを超える行の数を計算します。このカウントは、より高いスコアを獲得したプレーヤーの数を表すため、すべてのプレーヤーのコンテキストでのユーザーのランクが提供されます。
この SQL ベースのアプローチを実装することにより、全体をループする非効率なことなくランクの取得を実現できます。これにより、機能が最適化され、データベース ソリューションのスケーラビリティが向上します。
以上がSQL の順序なしスコア テーブルからユーザー ランクを効率的に取得する方法の詳細内容です。詳細については、PHP 中国語 Web サイトの他の関連記事を参照してください。