redis数据类型之有序集合 sorted set 博客分类: redis redisredis sort set
程序员文章站
2024-02-20 13:30:22
...
Redis 有序集合(sorted set)
Redis 有序集合和集合一样也是string类型元素的集合,且不允许重复的成员。
不同的是每个元素都会关联一个double类型的分数。redis正是通过分数来为集合中的成员进行从小到大的排序。
有序集合的成员是唯一的,但分数(score)却可以重复。
集合是通过哈希表实现的,所以添加,删除,查找的复杂度都是O(1)。 集合中最大的成员数为 232 - 1 (4294967295, 每个集合可存储40多亿个成员)。
redis 127.0.0.1:6379> zadd books 1 java
(integer) 1
redis 127.0.0.1:6379> zadd books 2 c++
(integer) 1
redis 127.0.0.1:6379> zadd books 3 c
(integer) 1
redis 127.0.0.1:6379> zadd books 4 lua
(integer) 1
redis 127.0.0.1:6379> zadd books 5 ruby
(integer) 1
redis 127.0.0.1:6379> zrange books 0 6
1) "java"
2) "c++"
3) "c"
4) "lua"
5) "ruby"
redis 127.0.0.1:6379> zrange books 0 6 withscores
1) "java"
2) "1"
3) "c++"
4) "2"
5) "c"
6) "3"
7) "lua"
以上通过命令 ZADD 向 redis 的有序集合中添加了三个值并关联上分数。
zaddkey score1 member1 [score2 member2]
向有序集合添加一个或多个成员,或者更新已存在成员的分数
获取成员数
redis 127.0.0.1:6379> zcard books
(integer) 5
zcount key min max 获取指定区间分数的成员数
redis 127.0.0.1:6379> zcount books 2 5
(integer) 4
zincrby 命令对有序集合中指定成员的分数加上增量 increment
可以通过传递一个负数值 increment ,让分数减去相应的值,比如 zincrby key -5 member ,就是让 member 的 score 值减去 5
。当 key 不存在,或分数不是 key 的成员时, zincrby key increment member 等同于 zadd key increment member当key不是有序
集类型时,返回一个错误。分数值可以是整数值或双精度浮点数。
示例:
redis 127.0.0.1:6379> zincrby books 1 1
"1"
redis 127.0.0.1:6379> zrange books 0 6 withscores
1) "1"
2) "1"
3) "java"
4) "1"
5) "c++"
6) "2"
7) "c"
"3"
9) "lua"
10) "4"
11) "ruby"
12) "5"
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 有序集合和集合一样也是string类型元素的集合,且不允许重复的成员。
不同的是每个元素都会关联一个double类型的分数。redis正是通过分数来为集合中的成员进行从小到大的排序。
有序集合的成员是唯一的,但分数(score)却可以重复。
集合是通过哈希表实现的,所以添加,删除,查找的复杂度都是O(1)。 集合中最大的成员数为 232 - 1 (4294967295, 每个集合可存储40多亿个成员)。
redis 127.0.0.1:6379> zadd books 1 java
(integer) 1
redis 127.0.0.1:6379> zadd books 2 c++
(integer) 1
redis 127.0.0.1:6379> zadd books 3 c
(integer) 1
redis 127.0.0.1:6379> zadd books 4 lua
(integer) 1
redis 127.0.0.1:6379> zadd books 5 ruby
(integer) 1
redis 127.0.0.1:6379> zrange books 0 6
1) "java"
2) "c++"
3) "c"
4) "lua"
5) "ruby"
redis 127.0.0.1:6379> zrange books 0 6 withscores
1) "java"
2) "1"
3) "c++"
4) "2"
5) "c"
6) "3"
7) "lua"
以上通过命令 ZADD 向 redis 的有序集合中添加了三个值并关联上分数。
zaddkey score1 member1 [score2 member2]
向有序集合添加一个或多个成员,或者更新已存在成员的分数
获取成员数
redis 127.0.0.1:6379> zcard books
(integer) 5
zcount key min max 获取指定区间分数的成员数
redis 127.0.0.1:6379> zcount books 2 5
(integer) 4
zincrby 命令对有序集合中指定成员的分数加上增量 increment
可以通过传递一个负数值 increment ,让分数减去相应的值,比如 zincrby key -5 member ,就是让 member 的 score 值减去 5
。当 key 不存在,或分数不是 key 的成员时, zincrby key increment member 等同于 zadd key increment member当key不是有序
集类型时,返回一个错误。分数值可以是整数值或双精度浮点数。
示例:
redis 127.0.0.1:6379> zincrby books 1 1
"1"
redis 127.0.0.1:6379> zrange books 0 6 withscores
1) "1"
2) "1"
3) "java"
4) "1"
5) "c++"
6) "2"
7) "c"
"3"
9) "lua"
10) "4"
11) "ruby"
12) "5"
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]
迭代有序集合中的元素(包括元素成员和元素分值)
上一篇: spring+maven实现邮件发送
下一篇: mybatis递归 一对多的实现方法示例