Redis学习笔记(七)——数据结构之有序集合(sorted set)
一、介绍
Redis有序集合和集合一样都是string类型元素的机会,且不允许重复的成员。
不同的是每个元素都会关联一个double类型的分数。Redis正是通过分数来为集合中的成员进行从小到放大的排序。
有序集合的成员是唯一的,但是分数(score)却可以重复。
集合是通过哈希表实现的,所以添加、删除、查找的复杂度都是O(1)。集合中最大的成员数为4294967295,每个集合可存储40多亿个成员。
基本命令:
- 添加/更新
zadd key score1 member1 [score2 member2 ...] (向有序集合添加一个或多个成员,或者更新已存在成员的分数)
zincrby key increment member (有序集合中对指定成员的分数上增量increment)
zinterstore destination numkeys key [key ...] (计算给定的一个或多个有序集的交集并将结果存储在新的有序集合key中)
- 查询
zcard key (获取有序集合的成员数)
zrange key start stop [withscores] (通过索引区间返回有序集合指定区间内的成员)
zcount key min max (计算在有序集合中指定区间分数的成员数)
zlexcount key min max (在有序集合中计算指定字典区间内成员数量)
zrangebylex key min max [limit offset count] (通过字典区间返回有序集合的成员)
zrangebyscore key min max [withscores] [limit] (通过分数返回有序集合指定区间内的成员)
zrank key member (返回有序集合中指定成员的索引)
zrevrange key start stop [withscores] (返回有序集合中指定区间内的成员,通过索引,分数从高到低)/(反转集合元素)
zrevrangebyscore key max min [withscores] (返回有序集合中指定分数区间内的成员,分数从高到低)
zrevrank key member (返回有序集合中指定成员的排名,有序集合成员按分数值递减,从达到小排序)
zscore key member (返回有序集合中,成员的分数值)
- 移除
zrem key member1 [member2 ...] (移除有序集合中的一个或多个成员)
zremrangebylex key min max (移除有序集合中给定的字典区间的成员)
zremrangebyrank key start stop (移除有序集合中给定的排名区间的成员)
zremrangebyscore key min max (移除有序集合中给定的分数区间的成员)
二、操作
- 添加
1、zadd key score1 member1 [score2 member2 ...] (向有序集合添加一个或多个成员,或者更新已存在成员的分数)
score为分数
2、zincrby key increment member (有序集合中对指定成员的分数上增量increment)
给集合添加一个元素c,分数为0
给元素c增加分数10
结果元素c分数值为10
3、zinterstore destination numkeys key [key ...] (计算给定的一个或多个有序集的交集并将结果存储在新的有序集合key中)
两个集合的元素(可以多个)
计算两个集合的交集并存储到新的集合中(分数值会获取集合中的最大值)
- 查询
1、zcard key (获取有序集合的成员数)
2、zrange key start stop [withscores] (通过索引区间返回有序集合指定区间内的成员)
获取集合所有元素
获取集合所有元素及分数
3、zcount key min max (计算在有序集合中指定区间分数的成员数)
4、zlexcount key min max (在有序集合中计算指定字典区间内成员数量)
5、zrangebylex key min max [limit offset count] (通过字典区间返回有序集合的成员)
6、zrangebyscore key min max [withscores] [limit] (通过分数返回有序集合指定区间内的成员)
7、zrank key member (返回有序集合中指定成员的索引)
如果指定元素(成员)不存在,返回(nil)
8、zrevrange key start stop [withscores] (返回有序集合中指定区间内的成员,通过索引,分数从高到低)/(反转集合元素)
就跟倒序一个道理
9、zrevrangebyscore key max min [withscores] (返回有序集合中指定分数区间内的成员,分数从高到低)
10、zrevrank key member (返回有序集合中指定成员的排名,有序集合成员按分数值递减,从达到小排序)
11、zscore key member (返回有序集合中,成员的分数值)
- 移除
1、zrem key member1 [member2 ...] (移除有序集合中的一个或多个成员)
如果删除的元素不存在返回0
2、zremrangebylex key min max (移除有序集合中给定的字典区间的成员)
3、zremrangebyrank key start stop (移除有序集合中给定的排名区间的成员)
4、zremrangebyscore key min max (移除有序集合中给定的分数区间的成员)