ホームページ >データベース >mysql チュートリアル >MySQL でグループ化されたランキング クエリを実行するにはどうすればよいですか?
MySQL グループ ランキング クエリ: 完全ガイド
データ処理では、グループ内の各レコードのランキングを決定する必要があることがよくあります。 MySQL では、この機能は ROW_NUMBER() や RANK() などのウィンドウ関数をグループ化句と組み合わせて使用することで実現できます。
次の形式を考えてみましょう:
学生ID (ID_STUDENT) | 班级ID (ID_CLASS) | 成绩 (GRADE) |
---|---|---|
1 | 1 | 90 |
1 | 2 | 80 |
2 | 1 | 99 |
3 | 1 | 80 |
4 | 1 | 70 |
5 | 2 | 78 |
6 | 2 | 90 |
6 | 3 | 50 |
7 | 3 | 90 |
グループ化されたランキングを作成するには、次のクエリを使用できます:
<code class="language-sql">SELECT id_student, id_class, grade, @student:=CASE WHEN @class = id_class THEN @student + 1 ELSE 1 END AS rn, @class:=id_class AS clset FROM (SELECT @student:= 0) s, (SELECT @class:= 0) c, (SELECT * FROM mytable ORDER BY id_class, grade DESC, id_student ) t;</code>
仕組み:
行の並べ替え: ORDER BY 句のサブクエリにより、データは最初に id_class
で並べ替えられ、次に grade
で降順に並べ替えられ、最後に id_student
で並べ替えられます。これにより、同じクラス内で成績の高い生徒が上位にランク付けされるようになります。
変数の初期化: 別々のサブクエリを使用して、2 つのユーザー定義変数 @student
と @class
を 0 に初期化します。これらの変数は、ランクとクラス グループをそれぞれ追跡するために使用されます。
グループ化とランキング: メイン クエリは CASE 式を使用して、各グループ内のランキングを決定します。同じグループ内の行 (id_class
に基づく) では、ランクが増分され、新しいグループではランクが 1 にリセットされます。変更された @student
変数にはランキング値が割り当てられます。
クラス グループの更新: @class
変数は、アクティブなグループを追跡するために、現在の id_class
値で更新されます。
最終結果: クエリは、ユーザー定義変数を使用して計算されたランク (rn) を含む、関連する列を選択します。
このグループ化されたランキング クエリを使用すると、MySQL のさまざまなクラス内の生徒のランキングを効率的に決定できます。この方法では、サブクエリ、ユーザー定義変数、条件ステートメントを組み合わせて、目的の結果を実現します。 この方法は元の記事とは若干異なることに注意してください。元の記事の変数の初期化と増分ロジックには問題があり、ランキング エラーが発生しやすいです。 この方法により、この問題が修正され、ランキング結果の正確さが保証されます。
以上がMySQL でグループ化されたランキング クエリを実行するにはどうすればよいですか?の詳細内容です。詳細については、PHP 中国語 Web サイトの他の関連記事を参照してください。