实时积分排行榜
需求
提供一个用户积分排行榜–为 实时总积分榜, 只取前 10 名 。所有用户都能够查看当前排行榜,以及查看自己的 实时总积分排名
设计实现
先看下数据库的结构,总共有 2 个表:用户表 和 用户积分表。
用户表存储了用户信息,以及用户的总积分(实时更新),也就是说总积分榜需要的数据可以直接从这里取到,不需要再去计算
用户表内容:
如果要取前 10 名,只需要把所有用户的信息先取出来,再排个序就好啦,写 SQL 语句查询的话就是:
select * from `user` order by score;
如果用户数特别多,比如几十万个,怎么查自己的总排名?
只需要先查出自己的分数,然后统计分数大于我的用户数量
先用 SQL 语句查出用户的分数:
/* 只取需要的列 */
select score as myScore
from