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