Mysql语句处理排序的两种方式

假设有张student表,记录了全级所有班级的所有学生的总成绩 字段 class_id,score,name

class_idnamescore
1张三498
2李四510
3王二520

第一种:利用了两层子查询的方式,首先在最外层查询所有列,在里层查询当前列的,班级相等,且分数大于当前列的数量当作排名。

select *, (
    select count(distinct score) from student s2 where s2.score >= s1.score and s1.class_id = s2.class_id
) as rank from student s1 

第二种:利用了两层子查询和变量,中心思想是,首先对所有列根据班级和分数排序,然后在每个班级中对所有分数累加标记数当作排名。
在最里层首先对班级和分数进行排序,并赋值变量,外层如果班级相等,则rank变量+1,classId变量赋值为当前行的班级id

select 
    s3.*,
    if(@classId=s3.class_id, @rank:=@rank+1, @rank=1),
    @classId:=s3.class_id
from
    (   
        select s1.* from student s1,(
            select @classId:=null, @rank:=0
        ) s2 order by s1.class_id, s1.score
    ) s3
  • 0
    点赞
  • 0
    收藏
    觉得还不错? 一键收藏
  • 打赏
    打赏
  • 0
    评论
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包

打赏作者

我就是全世界

你的鼓励将是我创作的最大动力

¥1 ¥2 ¥4 ¥6 ¥10 ¥20
扫码支付:¥1
获取中
扫码支付

您的余额不足,请更换扫码支付或充值

打赏作者

实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值