分别使用MongoDB和Redis的有序集合来实现排行榜功能。对比传统数据库的排序功能,寻找有序集合实现排序功能的优点。
具体到一个实际例子,比如说直播网站观众向主播送礼物的排行版,如果直接在数据库里面进行排序, 弊端有以下几点:
• 排行榜会实时更新,数据每一次变化都要排序,会对数据库的性能造成影响。. 频繁更新数据,导致数据库性能下降。
• 数据量太大时排序时间缓慢。
• 对被排序字段添加索引会占用更多空间。
使用redis有序集合进行排序:
(1).直接把MongoDB中的数据导入到Redis中名为rank的有序集合中:
(2).显示某一个特定用户的排名,具体代码如下:
(3).显示全部用户的排名,具体代码如下:
(4).运行效果:
有序集合具有唯一性(假设rk为排行榜名称,user1、user2等为玩家唯一标识)。score可以相同
免责声明:本站发布的内容(图片、视频和文字)以原创、转载和分享为主,文章观点不代表本网站立场,如果涉及侵权请联系站长邮箱:is@yisu.com进行举报,并提供相关证据,一经查实,将立刻删除涉嫌侵权内容。