关于mysql 自定义@row的使用

本文详细介绍了如何使用SQL在成绩或积分场景下实现排名功能,包括相同分数或积分时保持排名一致的方法,以及按积分插入时间进行排名的技巧。
部署运行你感兴趣的模型镜像
  • 应用场景:在对成绩或者积分排名时,往往需要显示排名;

    • 成绩排名:相同分数的人,名次相同

      Select s.Score,
          case 
            when @rowtotal = s.Score then cast(@rownum as SIGNED  INTEGER) # 当这个成绩和@rowtotal上一次的成绩相同时,@rownum不变
            when @rowtotal := s.Score then cast(@rownum :=@rownum +1 as SIGNED  INTEGER) # 当取到的成绩和上一次成绩不同时, @rownum +1 ,rank排名加一
            when @rowtotal = 0 then cast(@rownum :=@rownum +1 as SIGNED  INTEGER) # 当取到的成绩为0时,排名+1
          end as Rank 
      from 
      (select Id,Score from Scores order by Score desc)s, # 通过分数倒序排列成绩
      (Select @rownum :=0,@rowtotal :=null) r	#这个是关键,@rownum,@rowtotal先置空,然后和上边的成绩关联
    • 积分排名:按积分插入时间排名

      SELECT
          obj.score,@rownum := @rownum + 1 AS Rank
      FROM
          (
              SELECT
                  user_id,
                  score
              FROM
                  `sql_rank`
              ORDER BY
                  score DESC,
                  update_time ASC
          ) AS obj,
          (SELECT @rownum := 0) r

      我遇到的问题是,排名显示的是1.0,2.0的double类型,所以我用cast(@rownum as SIGNED INTEGER)转化了一下

您可能感兴趣的与本文相关的镜像

Stable-Diffusion-3.5

Stable-Diffusion-3.5

图片生成
Stable-Diffusion

Stable Diffusion 3.5 (SD 3.5) 是由 Stability AI 推出的新一代文本到图像生成模型,相比 3.0 版本,它提升了图像质量、运行速度和硬件效率

评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

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

余额充值