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  (移除有序集合中給定的分數區間的成員)

  

 

  

 

 


免責聲明!

本站轉載的文章為個人學習借鑒使用,本站對版權不負任何法律責任。如果侵犯了您的隱私權益,請聯系本站郵箱yoyou2525@163.com刪除。



 
粵ICP備18138465號   © 2018-2025 CODEPRJ.COM