关于mysql 自定义@row的使用

本文介绍了一种在数据库查询中实现成绩和积分排名的方法。对于成绩排名,相同分数的人员名次相同;对于积分排名,则根据积分及更新时间进行排序。文章解决了排名显示为double类型的问题,并提供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)转化了一下

转载于:https://www.cnblogs.com/lisongyu/p/10135380.html

评论
成就一亿技术人!
拼手气红包6.0元
还能输入1000个字符  | 博主筛选后可见
 
红包 添加红包
表情包 插入表情
 条评论被折叠 查看
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值