Redis 入門指南九:Redis 有序集合(sorted set)
Redis 有序集合(sorted set)
Redis 有序集合和集合一樣也是string型別元素的集合,且不允許重複的成員。
不同的是每個元素都會關聯一個double型別的分數。redis正是通過分數來為集合中的成員進行從小到大的排序。
有序集合的成員是唯一的,但分數(score)卻可以重複。
集合是通過雜湊表實現的,所以新增,刪除,查詢的複雜度都是O(1)其實不太準確。其實在redis sorted sets裡面當items內容大於64的時候同時使用了hash和skiplist兩種設計實現。這也會為了排序和查詢效能做的優化。所以如上可知: 新增和刪除都需要修改skiplist,所以複雜度為O(log(n))。 但是如果僅僅是查詢元素的話可以直接使用hash,其複雜度為O(1) 其他的range操作複雜度一般為O(log(n))當然如果是小於64的時候,因為是採用了ziplist的設計,其時間複雜度為O(n)
例項
在以上例項中我們通過命令 ZADD 向 redis 的有序集合中新增了三個值並關聯上分數。
Redis 有序集合命令
下表列出了 redis 有序集合的基本命令:
序號 | 命令及描述 |
---|---|
ZADD key score1 member1 [score2 member2] | 向有序集合新增一個或多個成員,或者更新已存在成員的分數 |
ZCARD key | 獲取有序集合的成員數 |
ZCOUNT key min max | 計算在有序集合中指定區間分數的成員數 |
ZINCRBY key increment member | 有序集合中對指定成員的分數加上增量 increment |
ZINTERSTORE destination numkeys key [key …] | 計算給定的一個或多個有序集的交集並將結果集儲存在新的有序集合 key 中 |
ZLEXCOUNT key min max | 在有序集合中計算指定字典區間內成員數量 |
ZRANGE key start stop [WITHSCORES] | 通過索引區間返回有序集合指定區間內的成員 |
ZRANGEBYLEX key min max [LIMIT offset count] | 通過字典區間返回有序集合的成員 |
ZRANGEBYSCORE key min max [WITHSCORES] [LIMIT] | 通過分數返回有序集合指定區間內的成員 |
ZRANK key member | 返回有序集合中指定成員的索引 |
ZREM key member [member …] | 移除有序集合中的一個或多個成員 |
ZREMRANGEBYLEX key min max | 移除有序集合中給定的字典區間的所有成員 |
ZREMRANGEBYRANK key start stop | 移除有序集合中給定的排名區間的所有成員 |
ZREMRANGEBYSCORE key min max | 移除有序集合中給定的分數區間的所有成員 |
ZREVRANGE key start stop [WITHSCORES] | 返回有序集中指定區間內的成員,通過索引,分數從高到低 |
ZREVRANGEBYSCORE key max min [WITHSCORES] | 返回有序集中指定分數區間內的成員,分數從高到低排序 |
ZREVRANK key member | 返回有序集合中指定成員的排名,有序整合員按分數值遞減(從大到小)排序 |
ZSCORE key member | 返回有序集中,成員的分數值 |
ZUNIONSTORE destination numkeys key [key …] | 計算給定的一個或多個有序集的並集,並儲存在新的 key 中 |
ZSCAN key cursor [MATCH pattern] [COUNT count] | 迭代有序集合中的元素(包括元素成員和元素分值) |
相關文章
- Redis 有序集合(sorted set)Redis
- Redis的有序集合(sorted set)Redis
- redis 有序集合(sorted set)(redis學習七)Redis
- Redis 入門 - 3(集合 set、有序集合 sort set)Redis
- redis原始碼分析(七)、redis命令學習總結—Redis 有序集合(sorted set)Redis原始碼
- redis有序集合型別sort setRedis型別
- redis有序集合Redis
- Redis 有序集合Redis
- Python&Redis 無序集合set、有序集合zset操作PythonRedis
- [Redis 系列]redis 學習四,set 集合,hash 雜湊,zset 有序集合初步認知Redis
- 【Redis 系列】redis 學習四,set 集合,hash 雜湊,zset 有序集合初步認知Redis
- Redis有序集合命令Redis
- Redis有序集合物件Redis物件
- Redis有序集合操作Redis
- Redis有序集合原理Redis
- Redis-Redis實戰(有序集合)Redis
- Redis有序集合詳解Redis
- Redis物件——有序集合(ZSet)Redis物件
- Redis有序集合學習Redis
- 《Redis實戰》筆記-Redis的有序集合Redis筆記
- redis 簡單使用(Sorted-Set)Redis
- redis-10.sorted_set型別Redis型別
- redis學習之有序集合Redis
- php操作redis,有序集合zsetPHPRedis
- Redis雜湊與有序集合Redis
- 【Redis 系列】redis 學習十四,sorted_set 初步探究梳理Redis
- Redis 有序集合(zset)命令詳解Redis
- 【Redis實戰】有序集合型別Redis型別
- go操作redis的有序集合(zset)GoRedis
- (免費領取紅包封面)【Redis 系列】redis 學習四,set 集合,hash 雜湊,zset 有序集合初步認知Redis
- (免費領取紅包封面)[Redis 系列]redis 學習四,set 集合,hash 雜湊,zset 有序集合初步認知Redis
- Redis的集合型別(Set)Redis型別
- 《閒扯Redis十一》Redis 有序集合物件底層實現Redis物件
- redis有序集合實現實時排名Redis
- Redis 資料庫之有序集合(zset)Redis資料庫
- redis原始碼分析(六)、redis命令學習總結—Redis 集合(Set)Redis原始碼
- Redis in .NET Core 入門:(4) LIST和SETRedis
- redis入門指南(六)—— 叢集Redis