9. Redis数据类型–Sorted Set
Redis 有序集合(sorted set)
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 有序集合命令
ZADD key score1 member1 [score2 member2]
向有序集合添加一个或多个成员,或者更新已存在成员的分数
ZCARD key
获取有序集合的成员数
ZCOUNT key min max
计算在有序集合中指定区间分数的成员数
ZINCRBY key increment member
有序集合中对指定成员的分数加上增量 increment
ZINTERSTORE destination numkeys key [key ...]
计算给定的一个或多个有序集的交集并将结果集存储在新的有序集合 destination 中
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]
迭代有序集合中的元素(包括元素成员和元素分值)
ZADD:有序集合添加元素
ZRANGE:获取集合元素
127.0.0.1:6379> zadd myset 1 a
(integer) 1
127.0.0.1:6379> ZADD myset 2 b
(integer) 1
127.0.0.1:6379> ZADD myset 3 c
(integer) 1
127.0.0.1:6379>
127.0.0.1:6379>
127.0.0.1:6379> ZRANGE myset 1 1
1) "b"
127.0.0.1:6379> ZRANGE myset 0 -1
1) "a"
2) "b"
3) "c"
ZRANGEBYSCORE:根据score(排序的值)
127.0.0.1:6379> ZRANGE myset 0 -1
1) "a"
2) "b"
3) "c"
127.0.0.1:6379> ZRANGEBYSCORE myset -inf +inf
1) "a"
2) "b"
3) "c"
127.0.0.1:6379> ZRANGEBYSCORE myset -inf +inf withscores
1) "a"
2) "1"
3) "b"
4) "2"
5) "c"
6) "3"
ZCARD:查询集合长度
127.0.0.1:6379> zrange myset 0 -1
1) "a"
2) "b"
3) "c"
127.0.0.1:6379>
127.0.0.1:6379>
127.0.0.1:6379> ZCARD myset
(integer) 3
ZREM:删除集合元素
127.0.0.1:6379> ZREM myset a
(integer) 1
127.0.0.1:6379> ZREM myset b
(integer) 1
127.0.0.1:6379> zrange myset 0 -1
1) "c"
ZCOUNT:最小最大值之间有多少个元素
127.0.0.1:6379> ZADD myset 1 a 10 b 100 c
(integer) 3
127.0.0.1:6379>
127.0.0.1:6379>
127.0.0.1:6379> zcount myset 1 1
(integer) 1
127.0.0.1:6379> zcount myset 1 10
(integer) 2
127.0.0.1:6379> zcount myset 1 100
(integer) 3
127.0.0.1:6379> zcount myset 1 1000
(integer) 3