Redis 有序集合

2021-08-04 10:26:54 字數 2478 閱讀 2543

redis 有序集合和集合一樣也是string型別元素的集合,且不允許重複的成員。

不同的是每個元素都會關聯乙個double型別的分數。redis正是通過分數來為集合中的成員進行從小到大的排序。

有序集合的成員是唯一的,但分數(score)卻可以重複。

集合是通過雜湊表實現的,所以新增,刪除,查詢的複雜度都是o(1)。 集合中最大的成員數為 232 - 1 (4294967295, 每個集合可儲存40多億個成員)。redis 127.0.0.1:6379> zadd runoobkey 1 redis

(integer) 1

redis 127.0.0.1:6379> zadd runoobkey 2 mongodb

(integer) 1

redis 127.0.0.1:6379> zadd runoobkey 3 mysql

(integer) 1

redis 127.0.0.1:6379> zadd runoobkey 3 mysql

(integer) 0

redis 127.0.0.1:6379> zadd runoobkey 4 mysql

(integer) 0

redis 127.0.0.1:6379> zrange runoobkey 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]

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

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 返...