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 サイトの他の関連記事を参照してください。