-
应用场景:在对成绩或者积分排名时,往往需要显示排名;
-
成绩排名:相同分数的人,名次相同
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)转化了一下
-
关于mysql 自定义@row的使用
最新推荐文章于 2023-09-26 10:30:48 发布
本文详细介绍了如何使用SQL在成绩或积分场景下实现排名功能,包括相同分数或积分时保持排名一致的方法,以及按积分插入时间进行排名的技巧。
部署运行你感兴趣的模型镜像
您可能感兴趣的与本文相关的镜像
Stable-Diffusion-3.5
图片生成
Stable-Diffusion
Stable Diffusion 3.5 (SD 3.5) 是由 Stability AI 推出的新一代文本到图像生成模型,相比 3.0 版本,它提升了图像质量、运行速度和硬件效率
1603

被折叠的 条评论
为什么被折叠?



