សំណួរ SQL ដើម្បីកំណត់បញ្ជីចំណាត់ថ្នាក់

ថ្ងៃនេះខ្ញុំបានបំពេញភារកិច្ចដូចខាងក្រោមខណៈពេលកំពុងធ្វើការលើគម្រោងអតិថិជន៖ យកតារាង 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   |
+--------+-----------+----------+
ថយក្រោយ