[一]增加元素
--->命令:ZADD key score member [score member]
--->向有序集合放入一个分数为score的member元素
--->元素存在,则用新分数更换旧分数。
--->命令返回新加入集合的元素,不包含之前已经存在的元素
--->分数不仅可以是整数,也可以是浮点数
--->+inf  -inf 表示正无穷和负无穷
 
 
[二]获得元素的分数
--->命令:ZSCORE key member
--->获得元素所关联的分数
 
 
[三]获得排名在某个范围内的元素的列表
--->命令:ZRANGE key start stop [WITHSCORES]
--->zrange 命令会按照元素分数从小到大的顺序返回索引从start到stop之间的所有元素(双闭区间)
--->如果获取元素列表的同时,还想获取元素对应的分数,在命令的最后加上withscores参数
--->索引从0开始。从左往右。-1表示右边第一个元素。[0,-1]表示返回所有元素
--->zrange命令的时间复杂度为O(log n+m),n为有序集合的基数,m为返回元素的个数
---> 如果两个元素的分数相等,redis会按(0-9,a-z,A-Z)顺序排序,
 
[四]获得排名在某个范围内的元素的列表
--->命令:ZREVRANGE key start stop [WITHSCORES]
--->命令会按照元素分数从大到小的顺序返回索引从start到stop之间的所有元素(双闭区间)
 
[五]获得指定分数范围的元素
--->命令:ZRANGEBYSCORE key min  max [WITHSCORES] [LIMIT offset count]
--->按从小到大的分数返回在min和max间(双闭区间)的元素
--->如果希望返回的元素,不包含两端点的值,则在分数前加“(”。
--->min max还支持无穷大。+inf正无穷  -inf负无穷
--->withscores标示返回元素列表的同时,还要返回分数
--->limit 从offset索引开始的count个人
[六]增加某个元素的分数
--->命令:ZINCRBY key increment  member
--->使key键里member元素的分数在原有基础上增加increment分数。
--->分数可以是正数,也可以是负数
--->返回值是增加后的分数。
 
[七]获得集合中元素的数量
--->命令:ZCARD key
--->获取key键集合中元素的数量
 
[八]获取指定分数范围内元素的个数
--->命令:ZCOUNT key min max
--->min max的取值规则和ZRANGEBYSCORE一样
 
[九]删除一个或多个元素
--->命令:ZREM key member [member...]
--->返回值是删除成功的元素。不存在的元素,不包括在内
 
[十]按照排名范围删除元素
--->命令:ZREMRANGEBYRANK key start stop
--->按照分数从小到大的顺序删除在指定排名范围内的所有元素,并返回删除的元素数量
 
[十一]按照分数范围删除元素
--->命令:ZREMRANGEBYSCORE key min max
--->按照分数从小到大的区间删除元素,并返回删除成功的元素个数
 
[十二]获得元素的排名
--->命令:ZRANK key member
--->按照分数从小到大的顺序,获得元素的排名。分数最小的元素排名0
--->命令:ZREVRANK key member
--->按照分数从大到小的顺序,拍的元素的排名。分数最大的元素排名0
 
[十三]计算有序集合的交集
--->命令:ZINTERSTORE destination numkeys key[ key ...] [WEIGHTS weight[weight ...]] [AGGERGATE SUM|MIN|MAX]
--->用来计算多个有序集合的交集,并将结果存储在destination键中(同样是按有序集合进行存储),返回的是destination中存储元素的个数
--->destination有序集合中元素的分数,是由参数AGGERGATE决定的。
(1)当AGGERGATE是sum的时候(也是默认值),destination键中元素的分数是每个参与计算的集合中该元素的分数之和
(2)当AGGERGATE是min的时候destination键中元素的分数是每个参与计算的集合中该元素的分数最小值
(3)当AGGERGATE是max的时候destination键中元素的分数是每个参与计算的集合中该元素的分数最大值
--->该命令还能够通过weights设置每个集合的权重,每个集合在参与计算时元素的分数会被乘上该集合的权重。
--->ZINTERSTORE是计算交集的。与该命令类似的还有:ZUNIONSTORE是计算集合并集的。

redis之(八)redis的有序集合类型的命令的更多相关文章

  1. 15天玩转redis —— 第六篇 有序集合类型

    今天我们说一下Redis中最后一个数据类型 “有序集合类型”,回首之前学过的几个数据结构,不知道你会不会由衷感叹,开源的世界真好,写这 些代码的好心人真的要一生平安哈,不管我们想没想的到的东西,在这个 ...

  2. Redis常用命令入门5:有序集合类型

    有序集合类型 上节我们一起学习了集合类型,感受到了redis的强大.现在我们接着学Redis的最后一个类型——有序集合类型. 有序集合类型,大家从名字上应该就可以知道,实际上就是在集合类型上加了个有序 ...

  3. Redis从基础命令到实战之有序集合类型(SortedSet)

    有序集合类型是Redis五种数据类型中最高级的.也是最复杂的类型.有序集合具有集合类型的特性,在其基础上给每个元素关联了一个分值,或称为权重,操作时既可以在添加元素时指定分值,也可以单独修改集合中某一 ...

  4. Redis自学笔记:3.6入门-有序集合类型

    3.6有序集合类型 3.6.1介绍 在集合类型基础上,为集合中每个元素都关联了一个分数,故可以获得 分数最高(最低)的前N个元素,可以获得指定范围内的元素等 有序集合中每个元素不同,但它们的分数却可以 ...

  5. 第二百九十九节,python操作redis缓存-SortSet有序集合类型,可以理解为有序列表

    python操作redis缓存-SortSet有序集合类型,可以理解为有序列表 有序集合,在集合的基础上,为每元素排序:元素的排序需要根据另外一个值来进行比较,所以,对于有序集合,每一个元素有两个值, ...

  6. redis:order set有序集合类型的操作(有序集合)

    1. order set有序集合类型的操作(有序集合) 有序集合是在无序集合的基础上加了一个排序的依据,这个排序依据叫score,因此声明一个集合为有序集合的时候要加上score(作为排序的依据) 1 ...

  7. Redis数据类型使用场景及有序集合SortedSet底层实现详解

    Redis常用数据类型有字符串String.字典dict.列表List.集合Set.有序集合SortedSet,本文将简单介绍各数据类型及其使用场景,并重点剖析有序集合SortedSet的实现. Li ...

  8. redis有序集合类型sort set

    redis的数据类型之-有序集合 sort set和set类型一样,也是string类型元素的集合,也没有重复的元素,不同的是sort set每个元素都会关联一个权,通过权值可以有序的获取集合中的元素 ...

  9. redis之有序集合类型(Zset)——排行榜的实现

    当数据库对排序支持的不是很好,可以利用redis有序集合排序 原文链接:http://blog.csdn.net/loophome/article/details/50373202

随机推荐

  1. Vue_WebPack小白入门

    Vue语法笔记 Vue项目搭建过程 Vue问题总结 去掉vue 中的代码规范检测(Eslint验证) 解决跨域请求问题 Vue推荐资料

  2. SRM13绵津见-终(扫描线+线段树/BIT)

    题目大意:求对于每个i求有多少个合法的j以及j对于几个i是合法的,合法的定义:l[i]<=x[j]<=r[i],T[i]-y[i]<=t[j]<=T[i]+y[i]. 设a[i ...

  3. mysql 读写分离,主从同步 理论

    mysql主从复制中:第一步:master记录二进制日志.在每个事务更新数据完成之前,master在二进制日志记录这些改变.MySQL将事务写入二进制日志,即使事务中的语句都是交叉执行的.在事件写入二 ...

  4. JavaScript数据类型转换方法汇总

    转换为布尔型 用两次非运算(!): 1 !!5 ==> true 用布尔型的构造函数: 1 new Boolean(5) == > true 值转换为布尔类型为false:0,+0,-0, ...

  5. POSIX.2 正则表达式

    By francis_hao    Oct 1,2017   这里的正则表达式主要是指扩展正则,也就是egrep(grep -e)用到的正则表达式. 字符 含义 类别说明 | 分割分支,正则表达式会去 ...

  6. STL之七:STL各种容器的使用时机详解

    转载于:http://blog.csdn.net/longshengguoji/article/details/8550235 C++标准程序库提供了各具特长的不同容器.现在的问题是:该如何选择最佳的 ...

  7. How Many Nines ZOJ - 3950 打表大法好

    If we represent a date in the format YYYY-MM-DD (for example, 2017-04-09), do you know how many 9s w ...

  8. HashMap详谈以及实现原理

    (一).HashMap 基于哈希表的 Map 接口的实现 允许使用 null 值和 null 键 HashMap不是线程安全,想要线程安全,Collections类的静态方法synchronizedM ...

  9. springboot-部署到centos7

    环境 系统:centos7 64位 安装jdk 第一步:下载 先进入官网:http://www.oracle.com/technetwork/java/javase/downloads/jdk8-do ...

  10. oracle 存储过程 技巧

    我们在进行pl/sql编程时打交道最多的就是存储过程了.存储过程的结构是非常的简单的,我们在这里除了学习存储过程的基本结构外,还会学习编写存储过程时相关的一些实用的知识.如:游标的处理,异常的处理,集 ...