Бүгүн мен кардардын долбоорун иштеп жатып, мындай тапшырмага туш болдум: "id" жана "балл" графалары менен "колдонуучу" SQL таблицасын алып, "упай" боюнча иреттелген бардык колдонуучулардын рейтинг тизмесин аныктаңыз. ошол эле рейтинг менен ошол эле упай менен алуу. Бул тапшырманы колдонуучу аныктап турган өзгөрмөлөрдү колдонуу менен интуитивдик жана оңой чечүүгө болот.
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 | +--------+-----------+----------+