文章详情

短信预约-IT技能 免费直播动态提醒

请输入下面的图形验证码

提交验证

短信预约提醒成功

MySQL中多种排名实现

2023-09-15 09:54

关注

文章目录

CREATE TABLE `forlan_score` (  `id` bigint(20) NOT NULL AUTO_INCREMENT COMMENT '主键ID',  `student_name` varchar(255) DEFAULT NULL COMMENT '学生名称',  `score` int(20) DEFAULT '-1' COMMENT '分数',`course_name` varchar(255) DEFAULT NULL COMMENT '课程',  PRIMARY KEY (`id`) USING BTREE) ENGINE=InnoDB AUTO_INCREMENT=1 DEFAULT CHARSET=utf8mb4 ROW_FORMAT=DYNAMIC COMMENT='学生成绩表';INSERT INTO `test`.`forlan_score` (`id`, `student_name`, `score`, `course_name`) VALUES (1, '小明', 70, '数学');INSERT INTO `test`.`forlan_score` (`id`, `student_name`, `score`, `course_name`) VALUES (2, '小红', 65, '英语');INSERT INTO `test`.`forlan_score` (`id`, `student_name`, `score`, `course_name`) VALUES (3, '小林', 100, '数学');INSERT INTO `test`.`forlan_score` (`id`, `student_name`, `score`, `course_name`) VALUES (4, '小黄', 100, '语文');INSERT INTO `test`.`forlan_score` (`id`, `student_name`, `score`, `course_name`) VALUES (5, '小东', 80, '语文');INSERT INTO `test`.`forlan_score` (`id`, `student_name`, `score`, `course_name`) VALUES (6, '小美', 90, '英语');INSERT INTO `test`.`forlan_score` (`id`, `student_name`, `score`, `course_name`) VALUES (7, '小伟', 88, '英语');INSERT INTO `test`.`forlan_score` (`id`, `student_name`, `score`, `course_name`) VALUES (8, '小小', 100, '数学');

1、不重复,连续

1.1、不同版本实现

1)mysql5.7实现

SET @cur_rank := 0;SELECTstudent_name,score,@cur_rank := @cur_rank + 1 AS ranking FROMforlan_score ORDER BYscore DESC;
SELECTfs.student_name,fs.score,( @cur_rank := @cur_rank + 1 ) AS ranking FROMforlan_score fs,( SELECT @cur_rank := 0 ) r ORDER BYscore DESC;

2)mysql8实现

ROW_NUMBER()

SELECTstudent_name,score,ROW_NUMBER() OVER ( ORDER BY score DESC ) AS ranking FROMforlan_score;

1.2、效果

+--------------+-------+---------+| student_name | score | ranking |+--------------+-------+---------+| 小林         |   100 |       1 || 小黄         |   100 |       2 || 小小         |   100 |       3 || 小美         |    90 |       4 || 小伟         |    88 |       5 || 小东         |    80 |       6 || 小明         |    70 |       7 || 小红         |    65 |       8 |+--------------+-------+---------+

2、并列排名,连续

2.1、不同版本实现

1)mysql5.7实现

SELECTfs.student_name,fs.score,IF( @pre_score = fs.score, @cur_rank, @cur_rank := @cur_rank + 1 ) AS ranking,@pre_score := fs.score FROMforlan_score fs,( SELECT @cur_rank := 0, @pre_score := NULL ) r ORDER BYfs.score DESC;
SELECTfs.student_name,fs.score,(CASEWHEN @pre_score = fs.score THEN @cur_rank WHEN @pre_score := fs.score THEN @cur_rank := @cur_rank + 1 END ) AS ranking FROMforlan_score fs,(SELECT @cur_rank := 0,@pre_score := NULL) r ORDER BYfs.score DESC;

2)mysql8实现

DENSE_RANK()

SELECTstudent_name,score,DENSE_RANK() OVER ( ORDER BY score DESC ) AS ranking FROMforlan_score;

2.2、效果

+--------------+-------+---------+| student_name | score | ranking |+--------------+-------+---------+| 小林         |   100 |       1 || 小黄         |   100 |       1 || 小小         |   100 |       1 || 小美         |    90 |       2 || 小伟         |    88 |       3 || 小东         |    80 |       4 || 小明         |    70 |       5 || 小红         |    65 |       6 |+--------------+-------+---------+

3、并列排名,不连续

3.1、不同版本实现

1)mysql5.7实现

SELECTfs.student_name,fs.score,@row_num := @row_num + 1,IF( @pre_score = fs.score, @cur_rank, @cur_rank := @row_num ) AS ranking,@pre_score := fs.score FROMforlan_score fs,(SELECT @cur_rank := 0,@pre_score := NULL,@row_num := 0 ) r ORDER BYfs.score DESC;
SELECTfs.student_name,fs.score,@row_num := @row_num + 1,( CASE WHEN @pre_score = fs.score THEN @cur_rank WHEN @pre_score := fs.score THEN @cur_rank := @row_num END ) AS ranking FROMforlan_score fs,( SELECT @cur_rank := 0, @pre_score := NULL, @row_num := 0 ) r ORDER BYfs.score DESC;

2)mysql8实现

RANK()

SELECTstudent_name,score,RANK() OVER ( ORDER BY score DESC ) AS ranking FROMforlan_score;

3.2、效果

+--------------+-------+---------+| student_name | score | ranking |+--------------+-------+---------+| 小林         |   100 |       1 || 小黄         |   100 |       1 || 小小         |   100 |       1 || 小美         |    90 |       4 || 小伟         |    88 |       5 || 小东         |    80 |       6 || 小明         |    70 |       7 || 小红         |    65 |       8 |+--------------+-------+---------+

1、不重复,连续

1.1、不同版本实现

1)mysql5.7实现

SELECTfs.student_name,fs.course_name,fs.score,IF(@cur_couse = course_name, @cur_rank := @cur_rank+1, @cur_rank :=1) AS ranking,@cur_couse := fs.course_nameFROMforlan_score fs,( SELECT @cur_rank := 0,  @cur_couse := NULL ) r ORDER BYfs.course_name,fs.score DESC;

2)mysql8实现

ROW_NUMBER()

SELECTstudent_name,course_name,score,ROW_NUMBER() OVER (PARTITION BY course_name ORDER BY course_name,score DESC) AS rankingFROMforlan_score;

1.2、效果

+--------------+-------------+-------+---------+| student_name | course_name | score | ranking |+--------------+-------------+-------+---------+| 小林         | 数学        |   100 |       1 || 小小         | 数学        |   100 |       2 || 小明         | 数学        |    70 |       3 || 小美         | 英语        |    90 |       1 || 小伟         | 英语        |    88 |       2 || 小红         | 英语        |    65 |       3 || 小黄         | 语文        |   100 |       1 || 小东         | 语文        |    80 |       2 |+--------------+-------------+-------+---------+

2、并列排名,连续

2.1、不同版本实现

1)mysql5.7实现

SELECTfs.student_name,fs.course_name,fs.score,IF(@cur_couse = course_name, IF( @pre_score = fs.score, @cur_rank, @cur_rank := @cur_rank+1 ), @cur_rank :=1) AS ranking,@pre_score := fs.score,@cur_couse := fs.course_nameFROMforlan_score fs,( SELECT @cur_rank := 0, @pre_score := NULL, @cur_couse := NULL ) r ORDER BYfs.course_name,fs.score DESC;

2)mysql8实现

DENSE_RANK()

SELECTstudent_name,course_name,score,DENSE_RANK() OVER (PARTITION BY course_name ORDER BY course_name,score DESC) AS rankingFROMforlan_score;

2.2、效果

+--------------+-------------+-------+---------+| student_name | course_name | score | ranking |+--------------+-------------+-------+---------+| 小林         | 数学        |   100 |       1 || 小小         | 数学        |   100 |       1 || 小明         | 数学        |    70 |       2 || 小美         | 英语        |    90 |       1 || 小伟         | 英语        |    88 |       2 || 小红         | 英语        |    65 |       3 || 小黄         | 语文        |   100 |       1 || 小东         | 语文        |    80 |       2 |+--------------+-------------+-------+---------+

3、并列排名,不连续

3.1、不同版本实现

1)mysql5.7实现

SELECTfs.student_name,fs.course_name,fs.score,IF(@cur_couse = course_name, @row_num := @row_num + 1, @row_num :=1),IF(@cur_couse = course_name, IF( @pre_score = fs.score, @cur_rank, @cur_rank := @row_num ),@cur_rank :=1) AS ranking,@pre_score := fs.score,@cur_couse := fs.course_nameFROMforlan_score fs,( SELECT @cur_rank := 0, @pre_score := NULL, @row_num := 0,@cur_couse := NULL ) r ORDER BYfs.course_name,fs.score DESC;

2)mysql8实现

RANK()

SELECTstudent_name,course_name,score,RANK() OVER (PARTITION BY course_name ORDER BY course_name,score DESC) AS rankingFROMforlan_score;

3.2、效果

+--------------+-------------+-------+---------+| student_name | course_name | score | ranking |+--------------+-------------+-------+---------+| 小林         | 数学        |   100 |       1 || 小小         | 数学        |   100 |       1 || 小明         | 数学        |    70 |       3 || 小美         | 英语        |    90 |       1 || 小伟         | 英语        |    88 |       2 || 小红         | 英语        |    65 |       3 || 小黄         | 语文        |   100 |       1 || 小东         | 语文        |    80 |       2 |+--------------+-------------+-------+---------+

来源地址:https://blog.csdn.net/qq_36433289/article/details/128676858

阅读原文内容投诉

免责声明:

① 本站未注明“稿件来源”的信息均来自网络整理。其文字、图片和音视频稿件的所属权归原作者所有。本站收集整理出于非商业性的教育和科研之目的,并不意味着本站赞同其观点或证实其内容的真实性。仅作为临时的测试数据,供内部测试之用。本站并未授权任何人以任何方式主动获取本站任何信息。

② 本站未注明“稿件来源”的临时测试数据将在测试完成后最终做删除处理。有问题或投稿请发送至: 邮箱/279061341@qq.com QQ/279061341

软考中级精品资料免费领

  • 历年真题答案解析
  • 备考技巧名师总结
  • 高频考点精准押题
  • 2024年上半年信息系统项目管理师第二批次真题及答案解析(完整版)

    难度     813人已做
    查看
  • 【考后总结】2024年5月26日信息系统项目管理师第2批次考情分析

    难度     354人已做
    查看
  • 【考后总结】2024年5月25日信息系统项目管理师第1批次考情分析

    难度     318人已做
    查看
  • 2024年上半年软考高项第一、二批次真题考点汇总(完整版)

    难度     435人已做
    查看
  • 2024年上半年系统架构设计师考试综合知识真题

    难度     224人已做
    查看

相关文章

发现更多好内容

猜你喜欢

AI推送时光机
位置:首页-资讯-数据库
咦!没有更多了?去看看其它编程学习网 内容吧
首页课程
资料下载
问答资讯