Redis有序集合

2021-09-02 00:13:00 字數 2299 閱讀 3241

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 有序集合的基本命令:

序號命令及描述

序號命令名稱

命令描述

1zadd key score1 member1 [score2 member2]

向有序集合新增乙個或多個成員,或者更新已存在成員的分數

2zcard key

獲取有序集合的成員數

3zcount key min max

計算在有序集合中指定區間分數的成員數

4zincrby key increment member

有序集合中對指定成員的分數加上增量 increment

5zinterstore destination numkeys key [key …]

計算給定的乙個或多個有序集的交集並將結果集儲存在新的有序集合 key 中

6zlexcount key min max

在有序集合中計算指定字典區間內成員數量

7zrange key start stop [withscores]

通過索引區間返回有序集合成指定區間內的成員

8zrangebylex key min max [limit offset count]

通過字典區間返回有序集合的成員

9zrangebyscore key min max [withscores] [limit]

通過分數返回有序集合指定區間內的成員

10zrank key member

返回有序集合中指定成員的索引

11zrem key member [member …]

移除有序集合中的乙個或多個成員

12zremrangebylex key min max

移除有序集合中給定的字典區間的所有成員

13zremrangebyrank key start stop

移除有序集合中給定的排名區間的所有成員

14zremrangebyscore key min max

移除有序集合中給定的分數區間的所有成員

15zrevrange key start stop [withscores]

返回有序集中指定區間內的成員,通過索引,分數從高到底

16zrevrangebyscore key max min [withscores]

返回有序集中指定分數區間內的成員,分數從高到低排序

17zrevrank key member

返回有序集合中指定成員的排名,有序集成員按分數值遞減(從大到小)排序

17zscore key member

返回有序集中,成員的分數值

18zunionstore destination numkeys key [key …]

計算給定的乙個或多個有序集的並集,並儲存在新的 key 中

19zscan key cursor [match pattern] [count count]

迭代有序集合中的元素(包括元素成員和元素分值)

Redis 有序集合

redis 有序集合和集合一樣也是string型別元素的集合,且不允許重複的成員。不同的是每個元素都會關聯乙個double型別的分數。redis正是通過分數來為集合中的成員進行從小到大的排序。有序集合的成員是唯一的,但分數 score 卻可以重複。集合是通過雜湊表實現的,所以新增,刪除,查詢的複雜度...

redis 有序集合

import redis pool redis.connectionpool host 127.0.0.1 實現乙個連線池 r redis.redis connection pool pool for i in range 100 r.zadd 1 i,i 表名稱為1,新增內容為 1到100,對應分...

Redis 有序集合

結構 key score value 集合和有序集合 都是沒有重複元素 集合是無序的 集合是element而有序集合是element score 列表和有序集合 列表可以有重複元素 列表是有序的 列表是element 有序集合中的排名是從小到大的排序的 重要api 新增score和element 返...