redis之有序集合型別(Zset)——排行榜的實現
原文:https://blog.csdn.net/loophome/article/details/50373202
Redis有序集合和Redis集合類似,是不包含 相同字串的合集。它們的差別是,每個有序集合 的成員都關聯著一個評分,這個評分用於把有序集 閤中的成員按最低分到最高分排列。
使用有序集合,你可以非常快地(O(log(N)))完成新增,刪除和更新元素的操作。 因為元素是在插入時就排好序的,所以很快地通過評分(score)或者 位次(position)獲得一個範圍的元素。 訪問有序集合的中間元素同樣也是非常快的,因此你可以使用有序集合作為一個沒用重複成員的智慧列表。 在這個列表中, 你可以輕易地訪問任何你需要的東西: 有序的元素,快速的存在性測試,快速訪問集合中間元素!
簡而言之,使用有序集合你可以很好地完成 很多在其他資料庫中難以實現的任務。
at first,我們先新增一下資料:
> zadd member_list 10 a 3 b 1 c 4 d 7 e
(integer) 5
#返回5,即成功加了5個進入集合。現在試試新增重複的元素
> zadd member_list 9 a 8 f
(integer) 1
#這個步驟,返回了1,而不是2,是因為a這個元素已經存在於集合當中了,不會新增成功。
> zrange member_list 0 6 WITHSCORES
1) "c"
2) 1.0
3) "b"
4) 3.0
5) "d"
6) 4.0
7) "e"
8) 7.0
9) "f"
10) 8.0
11) "a"
12) 9.0
可以看到,有序集合排序的規則是根據分母的大小,分母越小排在集合的前面
如下表顯示與排序集的一些基本命令:
我們可以實現的事情:
1.排行榜
排行榜是非常常見的實現,比如收入排行榜,積分排行榜。在某種情況下,可以直接快取整個排行榜,然後設定定時任務,在某個時間點更新。但對於一些實時性比較強的,需要及時更新資料,可以利用redis的有序佇列實現,原理是利用有序佇列的關聯評分。
PS:如果要自己實現,可以考慮使用二叉堆實現,效率能到到O(log(N))
#假定有一個實時的競技場評分,在玩家結束操作後打分,並動態顯示玩家的排行榜
> zadd rank 100 biki 87 zhibin 72 ming 64 fen 98 cat
(integer) 5
#顯示得分最高的前三名玩家
> ZREVRANGE rank 0 2 WITHSCORES
1) "biki"
2) 100.0
3) "cat"
4) 98.0
5) "zhibin"
6) 87.0
#此時aaa玩家結束遊戲得分為90
>zadd rank 90 aaa
#插入到有序佇列,在進行查詢
> zadd rank 90 aaa
(integer) 1
> ZREVRANGE rank 0 2 WITHSCORES
1) "biki"
2) 100.0
3) "cat"
4) 98.0
5) "aaa"
6) 90.0
排名已經更新了
相關文章
- Redis五大資料型別之 Zset(有序集合)Redis大資料資料型別
- Redis物件——有序集合(ZSet)Redis物件
- php操作redis,有序集合zsetPHPRedis
- 【Redis實戰】有序集合型別Redis型別
- Redis 有序集合(zset)命令詳解Redis
- 使用Redis的有序集合實現排行榜功能Redis
- Python&Redis 無序集合set、有序集合zset操作PythonRedis
- redis有序集合實現實時排名Redis
- [Redis 系列]redis 學習四,set 集合,hash 雜湊,zset 有序集合初步認知Redis
- 【Redis 系列】redis 學習四,set 集合,hash 雜湊,zset 有序集合初步認知Redis
- PHP+Redis 有序集合實現 24 小時排行榜實時更新PHPRedis
- Redis 設計與實現 10:五大資料型別之有序集合Redis大資料資料型別
- 《Redis實戰》筆記-Redis的有序集合Redis筆記
- Redis的ZSet底層資料結構,ZSet型別全面解析Redis資料結構型別
- 《閒扯Redis十一》Redis 有序集合物件底層實現Redis物件
- redis有序集合Redis
- Redis有序集合原理Redis
- Redis有序集合物件Redis物件
- Redis有序集合操作Redis
- Redis有序集合命令Redis
- Redis 設計與實現 9:五大資料型別之集合Redis大資料資料型別
- (免費領取紅包封面)[Redis 系列]redis 學習四,set 集合,hash 雜湊,zset 有序集合初步認知Redis
- (免費領取紅包封面)【Redis 系列】redis 學習四,set 集合,hash 雜湊,zset 有序集合初步認知Redis
- 使用 Redis 有序集合實現 IP 歸屬地查詢Redis
- Redis有序集合詳解Redis
- Redis有序集合學習Redis
- [Redis 基礎知識] Redis Zset 型別常用命令Redis型別
- Redis五大資料型別之 Set(集合)Redis大資料資料型別
- Redis雜湊與有序集合Redis
- redis學習之有序集合Redis
- redis的有序集的實現原理Redis
- 面試官:Redis中有序集合的內部實現方式是什麼?面試Redis
- redis 有序集合(sorted set)(redis學習七)Redis
- Redis 入門指南九:Redis 有序集合(sorted set)Redis
- [Redis]ZSetRedis
- 面試官:Redis中集合資料型別的內部實現方式是什麼?面試Redis資料型別
- Python–Redis實戰:第三章:Redis命令:第五節:有序集合PythonRedis
- Redis基本資料結構之ZSetRedis資料結構