Hodiaŭ mi renkontis la sekvan taskon laborante pri projekto de kliento: Prenu SQL-tablon "uzanto" kun la kolumnoj "id" kaj "poentaro" kaj determinu rangon de ĉiuj uzantoj laŭ "poentaro" en kiu uzantoj kun la akiru la saman rangotabelon kun la sama poentaro. Ĉi tiu tasko povas esti solvita intuicie kaj facile per uzantaj difinitaj variabloj .
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)
Uzi du variablojn solvas ĉi tion simple
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
kaj vi ricevas la deziratan rezulton
+--------+-----------+----------+ | *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 | +--------+-----------+----------+