MySQL中的三种常见的排名

news/2024/9/19 8:02:00/

三种常见的排名

row_number、dense_rank、rank在MySQL 5.7中的实现

文章目录

  • 三种常见的排名
        • 准备数据
          • 表结构说明
          • 创建SC表
          • 插入数据
        • ROW_NUMBER
        • DENSE_RANK
        • RANK
        • ROW_NUMBER
        • DENSE_RANK
        • RANK

准备数据

表结构说明
  • 成绩表 SC(SId,CId,score)
    • SId 学⽣编号

    • CId 课程编号

    • score 分数

创建SC表
create table SC(SId varchar(10),CId varchar(10),score decimal(18,1)
);
插入数据
-- 成绩表 SC 
insert into SC values('01' , '01' , 80); 
insert into SC values('01' , '02' , 90); 
insert into SC values('01' , '03' , 99); 
insert into SC values('02' , '01' , 70); 
insert into SC values('02' , '02' , 60); 
insert into SC values('02' , '03' , 80); 
insert into SC values('03' , '01' , 80); 
insert into SC values('03' , '02' , 80); 
insert into SC values('03' , '03' , 80); 
insert into SC values('04' , '01' , 50); 
insert into SC values('04' , '02' , 30); 
insert into SC values('04' , '03' , 20); 
insert into SC values('05' , '01' , 76); 
insert into SC values('05' , '02' , 87); 
insert into SC values('06' , '01' , 31); 
insert into SC values('06' , '03' , 34); 
insert into SC values('07' , '02' , 89); 
insert into SC values('07' , '03' , 98);

对SC中的学生score进行整体排名

ROW_NUMBER

1 2 3 4 5 6 7 没有重复排名,依次递增

SET @i := 0;
SELECT  t1.SId,t1.CId,t1.score,@i := @i + 1 as row_number
from (SELECT  SId,CId,scorefrom SCorder by score desc
) t1;

DENSE_RANK

1 2 3 3 3 4 5 6 7 有重复时并列排名,最终排名也是连续的

SET @i := 0;
SET @p := 0;
SET @q := 0;
SELECT  t1.SId,t1.CId,t1.score,@p := t1.score,if(@p=@q,@i,@i := @i+1) as dense_rank,@q :=@p
from (SELECT  SId,CId,scorefrom SCorder by score desc
) t1;

RANK

1 2 3 3 3 6 7 8 有重复时并列排名,最终排名不连续

SET @i := 0;
SET @j := 0;
SET @p := 0;
SET @q := 0;
SELECT  t1.SId,t1.CId,t1.score,@j := @j + 1,@p := t1.score,if(@p=@q,@i,@i := @j) as rank,@q :=@p
from (SELECT  SId,CId,scorefrom SCorder by score desc
) t1;

进行分组排名

ROW_NUMBER

查询每⻔课程成绩最好的前三名 1 2 3 4 5 6 7 没有重复排名,依次递增

SET @i := 0;
SET @p := 0;
SET @q := 0;
SELECT  tt1.SId,tt2.SName,tt1.CId,tt1.score,tt1.rn
from (select  t1.SId,t1.CId,t1.score,@p := t1.CId,if(@p=@q,@i := @i + 1,@i :=1) as rn,@q := @pfrom (select  SId,CId,scorefrom SCorder by CId,score DESC) t1
) tt1 join Student tt2 on tt1.rn<=3 and tt1.SId = tt2.SId
order by tt1.CId,tt1.rn;

DENSE_RANK

查询每⻔课程成绩最好的前三名 1 2 3 3 3 4 5 6 7 有重复时并列排名,最终排名也是连续的

SET @i := 0;
SET @p := 0;
SET @q := 0;
SET @j := 0;
SET @k := 0;
SELECT  tt1.SId,tt2.SName,tt1.CId,tt1.score,tt1.rn
from (select  t1.SId,t1.CId,t1.score,@p := t1.CId,@j := t1.score,if(@p=@q,if(@j=@k,@i,@i := @i + 1),@i :=1) as rn,@q := @p,@k := @jfrom (select  SId,CId,scorefrom SCorder by CId,score DESC) t1
) tt1 join Student tt2 on tt1.rn<=3 and tt1.SId = tt2.SId
order by tt1.CId,tt1.rn;

RANK

查询每⻔课程成绩最好的前三名 1 2 3 3 3 6 7 8 有重复时并列排名,最终排名不连续

SET @i := 0;
SET @p := 0;
SET @q := 0;
SET @j := 0;
SET @k := 0;
SET @m := 1;
SELECT  tt1.SId,tt2.SName,tt1.CId,tt1.score,tt1.rn
from (select  t1.SId,t1.CId,t1.score,@p := t1.CId,@j := t1.score,if(@p=@q,@m := @m + 1,@m := 1),if(@p=@q,if(@j=@k,@i,@i := @m),@i :=1) as rn,@q := @p,@k := @jfrom (select  SId,CId,scorefrom SCorder by CId,score DESC) t1
) tt1 join Student tt2 on tt1.rn<=3 and tt1.SId = tt2.SId
order by tt1.CId,tt1.rn;

http://www.ppmy.cn/news/217389.html

相关文章

手机耗电排名公布,第一名太意外了!

我们最亲近的&#xff0c;那莫过于手机了。除了洗澡睡觉&#xff0c;几乎所有时间我们都深度捆绑在一起 和手机关系密切的后果就是经常担心手机没电&#xff0c;也就是人们常说的“电量焦虑”。 现在手机电池的容量差不多已经饱和了&#xff0c;基本在 4000- 5000 毫安左右。 …

各种手机处理器排行榜_手机处理器CPU性能排名

0三星 Nexus S5427Android 2.3Hummingbird S5PC1101.44 GHz 超频 44%PowerVR SGX540 1三星 Facinate4427Android 2.3Hummingbird S5PC1101.40 GHz 超频 40%PowerVR SGX540 2三星 Nexus S4253Android 2.3Hummingbird S5PC1101.50 GHz 超频 50%PowerVR SGX540 3三星 Nexus S4098A…

手机什么处理器最好排名2021

那么当下手机处理器排名如何呢&#xff1f;又有哪些手机值得选择呢&#xff1f;一句话来说就是&#xff1a;苹果“超神”&#xff0c;高通第二&#xff0c;华为最高第四。我用的手机就是活动时7.5折抢购的 机会不容错过http://www.adiannao.cn/7 苹果超神 我们经常说苹果的iPho…

日撸java_day37

第 37 天: 十字链表 package datastructures.graph;/*** ClassName: OrthogonalList* Package: datastructures.graph* Description: Orthogonal List for directed graph.** Author: luv_x_c* Create: 2023/5/28 14:53*/ public class OrthogonalList {/*** An inner class f…

动态权限大全

1.android.permission.WRITE_USER_DICTIONARY 允许应用程序向用户词典中写入新词2.android.permission.WRITE_SYNC_SETTINGS 写入Google在线同步设置3.android.permission.WRITE_SOCIAL_STREAM 读取用户的社交信息流4.android.permission.WRITE_SMS 允许程序写短信5.android.pe…

FontAwesome图标大全

FontAwesome图标大全 FontAwesome图标大全 FontAwesome 4.7.0 图标大全&#xff0c;共计675个图标&#xff0c;以及其在图标字体中的Unicode编码cheatsheet列表&#xff0c;非常方便再WEB等开发过程中速查&#xff0c;一键复制&#xff0c;方便快捷。 https://tooltt.com/info…

支持蓝牙5.0手机大全

近两年发布的手机大都已取消3.5mm耳机孔&#xff0c;又由于没有线束缚&#xff0c;蓝牙耳机就这样一夜之间风靡开来。虽然都是蓝牙&#xff0c;但是各家耳机和手机采用的蓝牙技术却各不相同&#xff0c;比如现在很多耳机和手机就已经开始支持蓝牙5.0 了。那么蓝牙5.0 有什么好处…

qq里面cap字符_特殊符号大全

昵称专用特效字符: ︻︼︽︾〒↑↓☉⊙●〇◎★☆■▓「」『』◆◇▲△▼▽◣◥◢◣◤ ◥№↑↓→←↘↙Ψ※㊣∑⌒∩【】〖〗@ξζω□∮〓※》∏卐√ ╳々♀♂∞①ㄨ≡╬╭╮╰╯╱╲ ▂ ▂ ▃ ▄ ▅ ▆ ▇ █ ▂▃▅▆█ ▁▂▃▄▅▆▇█▇▆▅▄▃▂▁ 基础各类贴图符号…

GM命令代码大全

2871129715 1565079105 3154918763 3213860268 3013579557 3334928235 2535351329 /sro 唤醒 物品第一格子 /sro 1 511 2 511 77 511 说明一下77表示的杀死加伤害511 表示加伤害511 唤醒最多加511 1 表示加力量 2 表示加敏捷 3 表示加智力 4 表示加体力 9 表…

2022蓝牙耳机哪款更值得买?最受欢迎的十大蓝牙耳机排行榜

对于一个爱研究蓝牙耳机的学生党来说&#xff0c;蓝牙耳机在我生活中不可缺少。蓝牙耳机的便携程度极高&#xff0c;音质与有线耳机几乎无差&#xff0c;在生活中的便携使用让我越用越爱。听歌、追剧、打游戏&#xff0c;避免尴尬的同时还能带来极致的声音体验&#xff0c;声临…

通讯协议大全

目录 一、物理层、数据链路层协议 1、远距离蜂窝通信 &#xff08;1&#xff09;2G/3G/4G通信协议 &#xff08;2&#xff09;NB-IoT &#xff08;3&#xff09;5G 2、远距离非蜂窝通信 &#xff08;1&#xff09;WiFi &#xff08;2&#xff09;ZigBee &#xff08;3…

android 权限大全

访问登记属性 android.permission.ACCESS_CHECKIN_PROPERTIES &#xff0c;读取或写入登记check-in数据库属性表的权限 获取错略位置 android.permission.ACCESS_COARSE_LOCATION&#xff0c;通过WiFi或移动基站的方式获取用户错略的经纬度信息&#xff0c;定位精度大概误差在3…

大麦盒子(domybox)无法进入系统解决方案!【简单几步】

大麦盒子&#xff08;domybox&#xff09;无法进入系统解决方案&#xff01;【简单几步】 参考文章&#xff1a; &#xff08;1&#xff09;大麦盒子&#xff08;domybox&#xff09;无法进入系统解决方案&#xff01;【简单几步】 &#xff08;2&#xff09;https://www.cnb…

大麦自动抢票

直接来干货&#xff0c;需要准备工具&#xff1a;chrome&#xff0c;Tampermonkey。 第一步提前找到你要看到的演唱会&#xff0c;确定好日期、座次以及登陆时默认的收货信息&#xff1a; 第二部确认订单&#xff1a; 以上仅展示一部分&#xff0c;亲测有效哦。

大麦链接 大麦购票链接万能模版

后台更新了大麦链接 大麦万能模版

大麦盒子无线服务器连接超时,大麦盒子游戏联网失败怎么办

大麦盒子游戏联网失败怎么办&#xff1f;最近有很多玩家都对此有所疑问&#xff0c;今天安致小编为大家带来了大麦盒子游戏联网失败解决方法&#xff0c;感兴趣的玩家赶紧来安致网看看吧。 大麦盒子游戏联网失败解决方法 1、路由器正常工作的&#xff0c;但是搜索不到无线信号&…

python手机端抢票大麦网_大麦网抢票攻略1.0

前一阵子从粉丝群里得知杰伦要在泉州开演唱会&#xff0c;就一直盼着大麦网开票。做了不少攻略&#xff0c;在结合实际做了一个抢票攻略。怎么样用最少的钱抢到最好的位置&#xff01; 看图 从座位图可以看出来&#xff0c;780这个票价的座位可以从舞台侧面一直到远离舞台的位…

2023.03.27更新大麦网PC端抢购软件和使用教程

文章目录 前言新的解决方案订阅须知你的建议 前言 近期发现大麦网页端抢购页面悄然发生变化&#xff0c;之前可以在页面选择票价、档次&#xff0c;并且点击按钮进行购票&#xff0c;现在不行了。 新的解决方案 新的代码中首先进行了如下改造。 构造下单地址。之前是需要在…

关于大麦网接口抢票构造的一些思路

文章目录 前言分析思路登录模块检测登录状态接口获取商品信息参数获取点击购买所必须的参数信息点击立即购买提交订单所需参数信息前言 之前写的基于selenium版本的大麦网抢票思路,比较依赖页面元素,如果网页元素经常发生变动,代码需要随之改动,并且随着后期验证码的出现,…

2023.04.22更新大麦网移动端/M端抢购软件和使用教程

文章目录 前言新的解决方案订阅须知早期代码 前言 近期发现大麦网页端抢购页面悄然发生变化&#xff0c;之前可以在页面选择票价、档次&#xff0c;并且点击按钮进行购票&#xff0c;现在不行了&#xff0c;并且有些票只能在APP端购买&#xff0c;因此针对性编写了代码来适配。…