Redis 有序集合(sorted set)
Redis 有序集合和集合一樣也是string類型元素的集合,且不允許重複的成員。
不同的是每個元素都會關聯一個double類型的分數。 redis正是透過分數來為集合中的成員進行從小到大的排序。
有序集合的成員是唯一的,但分數(score)卻可以重複。
集合是透過哈希表實現的,所以添加,刪除,查找的複雜度都是O(1)。 集合中最大的成員數為 232 - 1 (4294967295, 每個集合可儲存40多億個成員)。
實例
redis 127.0.0.1:6379> ZADD w3ckey 1 redis (integer) 1 redis 127.0.0.1:6379> ZADD w3ckey 2 mongodb (integer) 1 redis 127.0.0.1:6379> ZADD w3ckey 3 mysql (integer) 1 redis 127.0.0.1:6379> ZADD w3ckey 3 mysql (integer) 0 redis 127.0.0.1:6379> ZADD w3ckey 4 mysql (integer) 0 redis 127.0.0.1:6379> ZRANGE w3ckey 0 10 WITHSCORES 1) "redis" 2) "1" 3) "mongodb" 4) "2" 5) "mysql" 6) "4"
在上述實例中我們透過指令 ZADD 向 redis 的有序集合中加入了三個值並關聯上分數。
Redis 有序集合指令
下表列出了 redis 有序集合的基本指令:
序號 | 指令及描述 |
---|---|
1 | ZADD key score1 member1 [score2 member2] 在有序集合中新增一個或多個成員,或更新已存在成員的分數 |
2 | ZCARD key 取得有序集合的成員數 |
3 | ZCOUNT key min max 計算有序集合中指定區間分數的成員數 |
4 | ZINCRBY key increment member 有序集合中對指定成員的分數加上增量increment |
5 | ZINTERSTORE destination numkeys key [key ...] 計算給定的一個或多個有序集的交集並將結果集存儲在新的有序集合key 中 |
6 | ZLEXCOUNT key min max 在有序集合中計算指定字典區間內成員數量 |
7 | ZRANGE key start stop [WITHSCORES ] 透過索引區間傳回有序集合成指定區間內的成員 |
8 | ZRANGEBYLEX key min max [LIMIT offset count] 透過字典區間傳回有序集合的成員 |
9 | ZRANGEBYSCORE key min max [WITHSCORES] [LIMIT] 透過分數傳回有序集合指定區間內的成員 |
10 | ZRANK key member 傳回有序集合中指定成員的索引 |
11 | ZREM key member [member ...] 移除有序集合中的一個或多個成員 |
12 | ZREMRANGEBYLEX key min max 移除有序集合中給定的字典區間的所有成員 |
13 | ZREMRANGEBYRANK key start stop 移除有序集合中給定的排名區間的所有成員 |
14 | ZREMRANGEBYSCORE key min max 移除有序集合中給定的分數區間的所有成員 |
15 | ZREVRANGE key start stop [WITHSCORES] 傳回有序集中指定區間內的成員,透過索引,分數從高到底 |
#16 | ZREVRANGEBYSCORE key max min [WITHSCORES] 傳回有序集中指定分數區間內的成員,分數從高到低排序 |
#17 | ZREVRANK key member 傳回有序集合中指定成員的排名,有序集成員會依分數值遞減(由大到小)排序 |
18 | ZSCORE key member 傳回有序集中,成員的分數值 |
19 | ZUNIONSTORE destination numkeys key [key ... ] 計算給定的一個或多個有序集的並集,並儲存在新的key 中 |
#20 | ##ZSCAN key cursor [MATCH pattern] [COUNT count]迭代有序集合中的元素(包括元素成員和元素分值) |