ホームページ >データベース >mysql チュートリアル >MySQL の複数の列に基づいてユーザーをランク付けするにはどうすればよいですか?

MySQL の複数の列に基づいてユーザーをランク付けするにはどうすればよいですか?

DDD
DDDオリジナル
2024-12-29 09:45:10265ブラウズ

How to Rank Users Based on Multiple Columns in MySQL?

MySQL の複数の列に基づいてランクを決定する

MySQL でデータを操作する場合、多くの場合、複数の列に基づいて行のランクを決定する必要があります。特定の基準に基づいて。この場合、タスクには、ユーザー ID とゲーム ID の両方に基づいてユーザーをランク付けし、そのランキングをゲームの詳細の降順で並べることが含まれます。

この問題に対処するために、サブクエリを利用して次のようなデータを並べ替えます。同じユーザー ID を持つすべての行がグループ化され、ゲームの詳細に基づいて降順でさらに並べ替えられます。次に、条件付き CASE..WHEN 式を使用して行番号を評価し、ユーザー ゲーム ランクを割り当てます。

次の SQL クエリが解決策を提供します。

SET @r := 0, @u := 0; 
SELECT
  @r := CASE WHEN @u = dt.user_id 
                  THEN @r + 1
             WHEN @u := dt.user_id /* Notice := instead of = */
                  THEN 1 
        END AS user_game_rank, 
  dt.user_id, 
  dt.game_detail, 
  dt.game_id 

FROM 
( SELECT user_id, game_id, game_detail
  FROM game_logs 
  ORDER BY user_id, game_detail DESC 
) AS dt 

クエリでは、ユーザー定義変数 @r および @u を使用して、行ランキングとユーザー ID を追跡します。 user_game_rank の評価と @u へのユーザー ID の割り当てが同じ式内で行われ、正しい順序が維持されるようにします。

このクエリの結果は、希望どおりのユーザー ゲーム ランクを提供します。

| user_game_rank | user_id | game_detail | game_id |
| -------------- | ------- | ----------- | ------- |
| 1              | 6       | 260         | 11      |
| 2              | 6       | 100         | 10      |
| 1              | 7       | 1200        | 10      |
| 2              | 7       | 500         | 11      |
| 3              | 7       | 260         | 12      |
| 4              | 7       | 50          | 13      |

MySQL 8.0 以降の場合、より効率的なアプローチは Row_Number() 関数を使用することです。この関数は、指定されたデータに基づいて行ランキングを直接計算できます。 criteria:

SELECT user_id, 
       game_id, 
       game_detail, 
       ROW_NUMBER() OVER (PARTITION BY user_id 
                          ORDER BY game_detail DESC) AS user_game_rank 
FROM game_logs 
ORDER BY user_id, user_game_rank;

このクエリは前のクエリと同じ出力を提供しますが、パフォーマンスが向上しており、MySQL 8.0 の行ランキングに推奨される方法です。

以上がMySQL の複数の列に基づいてユーザーをランク付けするにはどうすればよいですか?の詳細内容です。詳細については、PHP 中国語 Web サイトの他の関連記事を参照してください。

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