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

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

Susan Sarandon
Susan Sarandonオリジナル
2024-12-30 08:14:09407ブラウズ

How to Rank Rows in MySQL Based on Multiple Columns?

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

クエリ:

ベースで行をランク付けするには複数の列 (user_id と game_id) の降順を考慮しながらgame_detail_sum では、サブクエリと条件 CASE 式を使用できます。

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 

説明:

  1. サブクエリは、各行の game_detail_sum の降順に行を並べます。 user_id.
  2. 外部クエリはユーザー定義変数 @r を使用します(行ランク) と @u (前の user_id) を使用して行番号を割り当てます。

MySQL 8 Row_Number() 関数によるクエリの改善:

MySQL 8.0 では、 Row_Number() 関数。より効率的な行を可能にします。番号付け:

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;

補足:

  • 元のアプローチでは、同じクエリで ORDER BY とユーザー変数を使用すると、正しい結果が保証されない可能性があります。
  • Row_Number() を使用した改良されたクエリのパフォーマンスが向上しました。 MySQL 8 で予測可能な結果を​​提供します。

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

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