MySQL
发布时间:2022-05-15 发布网站:大佬教程 code.js-code.com
大佬教程收集整理的这篇文章主要介绍了MySQL实现排名并查询指定用户排名功能,并列排名功能,大佬教程大佬觉得挺不错的,现在分享给大家,也给大家做个参考。
<h1 class="title-article">MysqL实现排名并查询指定用户排名功能,并列排名功能
表结构:
id int(11) NOT NULL AUTO_INCREMENT,
uid int(11) DEFAULT 0 COMMENT '用户id',
score
decimal(10,2) DEFAULT 0.00 COMMENT '分数',
)
AUTO_INCREMENT = 1
CHaraCTER SET utf8
COLLATE utf8_general_ci
COMMENT = '测试排序'
思路:可以先排序,再对结果进行编号;也可以先查询结果,再排序编号。
说明:
@rownum := @rownum + 1中 := 是赋
值的作用,这句话的意思是先执行@rownum + 1,然后把值赋给@rownum;
(SELECT @rownum := 0) r这句话的意思是
设置rownum字段的初始值为0,即编号从1开始。
实现排名:
方法一:
方法二:
结果:
查看指定用户排名:
方法一:
(
) AS b WHERE b.uid = 222;
方法二:
(
ORDER BY t.score DESC
) as b where b.uid = 222;
结果:
实现并列排名(相同分数排名相同):
obj.uid,
obj.score,
CASE
WHEN @row@R_842_1
0586@l = obj.score THEN
@rownum
WHEN @row@R_842_1
0586@l := obj.score THEN
@rownum :=@rownum + 1
WHEN @row@R_842_1
0586@l = 0 THEN
@rownum :=@rownum + 1
END AS rownum
FROM
(
uid,
score
FROM
testsort
ORDER BY
score DESC
) AS obj,
(SELECT @rownum := 0,@row@R_842_1
0586@l := NULL) r
查询指定用户并列排名:
obj.uid,@row@R_842_1
0586@l := NULL) r) AS @R_842_1
0586@l WHERE @R_842_1
0586@
l.uid = 222;
大佬总结
以上是大佬教程为你收集整理的MySQL实现排名并查询指定用户排名功能,并列排名功能全部内容,希望文章能够帮你解决MySQL实现排名并查询指定用户排名功能,并列排名功能所遇到的程序开发问题。
如果觉得大佬教程网站内容还不错,欢迎将大佬教程推荐给程序员好友。
本图文内容来源于网友网络收集整理提供,作为学习参考使用,版权属于原作者。
如您有任何意见或建议可联系处理。小编QQ:384754419,请注明来意。