MySQL   发布时间:2022-05-15  发布网站:大佬教程  code.js-code.com
大佬教程收集整理的这篇文章主要介绍了MySQL实现排名并查询指定用户排名功能,并列排名功能大佬教程大佬觉得挺不错的,现在分享给大家,也给大家做个参考。

<h1 class="title-article">MysqL实现排名并查询指定用户排名功能,并列排名功能

表结构:
create table test.testsort (
id int(11) NOT NULL AUTO_INCREMENT,
uid int(11) DEFAULT 0 COMMENT '用户id',
score decimal(10,2) DEFAULT 0.00 COMMENT '分数',
)
ENGINE = INNODB
AUTO_INCREMENT = 1
CHaraCTER SET utf8
COLLATE utf8_general_ci
COMMENT = '测试排序'
ROW_FORMAT = DYNAMIc;
思路:可以先排序,再对结果进行编号;也可以先查询结果,再排序编号。
说明:
@rownum := @rownum + 1中 := 是赋值的作用,这句话的意思是先执行@rownum + 1,然后把值赋给@rownum;
(SELECT @rownum := 0) r这句话的意思是设置rownum字段的初始值为0,即编号从1开始。
实现排名:
方法一:
select t.*,@rownum := @rownum + 1 AS rownum
FROM (SELECT @rownum := 0) r,(SELECT * FROM testsort ORDER BY score desc) AS t;
方法二:
select t.*,testsort AS t
ORDER BY t.score DESc;
结果:

MySQL实现排名并查询指定用户排名功能,并列排名功能

查看指定用户排名:
方法一:
SELECT b.* FROM
(
(SELECT * FROM testsort ORDER BY score desc) AS t
) AS b WHERE b.uid = 222;
方法二:
SELECT b.* from
(
select t.*,testsort AS t
ORDER BY t.score DESC
) as b where b.uid = 222;
结果:

MySQL实现排名并查询指定用户排名功能,并列排名功能

实现并列排名(相同分数排名相同):
obj.uid,
obj.score,
CASE
WHEN @row@R_842_10586@l = obj.score THEN
@rownum
WHEN @row@R_842_10586@l := obj.score THEN
@rownum :=@rownum + 1
WHEN @row@R_842_10586@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_10586@l := NULL) r

MySQL实现排名并查询指定用户排名功能,并列排名功能

查询指定用户并列排名:
SELECT @R_842_10586@l.* FROM
obj.uid,@row@R_842_10586@l := NULL) r) AS @R_842_10586@l WHERE @R_842_10586@l.uid = 222;

MySQL实现排名并查询指定用户排名功能,并列排名功能

大佬总结

以上是大佬教程为你收集整理的MySQL实现排名并查询指定用户排名功能,并列排名功能全部内容,希望文章能够帮你解决MySQL实现排名并查询指定用户排名功能,并列排名功能所遇到的程序开发问题。

如果觉得大佬教程网站内容还不错,欢迎将大佬教程推荐给程序员好友。

本图文内容来源于网友网络收集整理提供,作为学习参考使用,版权属于原作者。
如您有任何意见或建议可联系处理。小编QQ:384754419,请注明来意。
标签: