আজ আমি গ্রাহক প্রকল্পে কাজ করার সময় নীচের কাজটি পেরিয়ে এসেছি: কলামগুলি "আইডি" এবং "স্কোর" সহ একটি এসকিউএল টেবিল "ব্যবহারকারী" নিন এবং "স্কোর" অনুসারে বাছাই করা সমস্ত ব্যবহারকারীর একটি র্যাঙ্কিং তালিকা নির্ধারণ করুন যার সাথে ব্যবহারকারীরা একই স্কোর সহ একই র্যাঙ্কিং পান। এই কার্যটি ব্যবহারকারী-সংজ্ঞায়িত ভেরিয়েবলগুলি ব্যবহার করে স্বজ্ঞাত এবং সহজেই সমাধান করা যেতে পারে।
CREATE TABLE
user(id INT, score INT);
INSERT INTO
user(id, score)
VALUES
(1, 10), (2, 40), (3, 55), (4, 10), (5, 5), (6, 20), (7, 30), (8, 70), (9, 30)
দুটি ভেরিয়েবল ব্যবহার করা সহজভাবে এটি সমাধান করে
SET @score_prev = NULL;
SET @cur_rank = 0;
SELECT id, score, CASE
WHEN @score_prev = score THEN @cur_rank
WHEN @score_prev := score THEN @cur_rank := @cur_rank + 1
END AS rank
FROM user
ORDER BY score DESC
এবং আপনি চান আউটপুট পেতে
+--------+-----------+----------+ | *id* | *score* | *rank* | | 8 | 70 | 1 | | 3 | 55 | 2 | | 2 | 40 | 3 | | 7 | 30 | 4 | | 9 | 30 | 4 | | 6 | 20 | 5 | | 1 | 10 | 6 | | 4 | 10 | 6 | | 5 | 5 | 7 | +--------+-----------+----------+