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  (移除有序集合中给定的分数区间的成员)

  

  

 

 

原文地址:https://www.cnblogs.com/hejianliang/p/9561851.html