分别使用MongoDB和Redis的有序集合来实现排行榜功能。对比传统数据库的排序功能,寻找有序集合实现排序功能的优点。

具体到一个实际例子,比如说直播网站观众向主播送礼物的排行版,如果直接在数据库里面进行排序, 弊端有以下几点:
    • 排行榜会实时更新,数据每一次变化都要排序,会对数据库的性能造成影响。. 频繁更新数据,导致数据库性能下降。
    • 数据量太大时排序时间缓慢。
    • 对被排序字段添加索引会占用更多空间。

使用redis有序集合进行排序:

    (1).直接把MongoDB中的数据导入到Redis中名为rank的有序集合中:

        

        

    (2).显示某一个特定用户的排名,具体代码如下:

        

    (3).显示全部用户的排名,具体代码如下:

        

    (4).运行效果:

        


    有序集合具有唯一性(假设rk为排行榜名称,user1、user2等为玩家唯一标识)。score可以相同