ホームページ >データベース >mysql チュートリアル >MySQL でグループ化されたランキング クエリを実行するにはどうすればよいですか?

MySQL でグループ化されたランキング クエリを実行するにはどうすればよいですか?

Patricia Arquette
Patricia Arquetteオリジナル
2025-01-17 19:32:11557ブラウズ

How to Perform Grouped Ranking Queries in 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>

仕組み:

  1. 行の並べ替え: ORDER BY 句のサブクエリにより、データは最初に id_class で並べ替えられ、次に grade で降順に並べ替えられ、最後に id_student で並べ替えられます。これにより、同じクラス内で成績の高い生徒が上位にランク付けされるようになります。

  2. 変数の初期化: 別々のサブクエリを使用して、2 つのユーザー定義変数 @student@class を 0 に初期化します。これらの変数は、ランクとクラス グループをそれぞれ追跡するために使用されます。

  3. グループ化とランキング: メイン クエリは CASE 式を使用して、各グループ内のランキングを決定します。同じグループ内の行 (id_class に基づく) では、ランクが増分され、新しいグループではランクが 1 にリセットされます。変更された @student 変数にはランキング値が割り当てられます。

  4. クラス グループの更新: @class 変数は、アクティブなグループを追跡するために、現在の id_class 値で更新されます。

  5. 最終結果: クエリは、ユーザー定義変数を使用して計算されたランク (rn) を含む、関連する列を選択します。

このグループ化されたランキング クエリを使用すると、MySQL のさまざまなクラス内の生徒のランキングを効率的に決定できます。この方法では、サブクエリ、ユーザー定義変数、条件ステートメントを組み合わせて、目的の結果を実現します。 この方法は元の記事とは若干異なることに注意してください。元の記事の変数の初期化と増分ロジックには問題があり、ランキング エラーが発生しやすいです。 この方法により、この問題が修正され、ランキング結果の正確さが保証されます。

以上がMySQL でグループ化されたランキング クエリを実行するにはどうすればよいですか?の詳細内容です。詳細については、PHP 中国語 Web サイトの他の関連記事を参照してください。

声明:
この記事の内容はネチズンが自主的に寄稿したものであり、著作権は原著者に帰属します。このサイトは、それに相当する法的責任を負いません。盗作または侵害の疑いのあるコンテンツを見つけた場合は、admin@php.cn までご連絡ください。