[一]增加元素
--->命令: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. apache出现You don't have permission to access / on this server. 提示

    今天在新的linux上跑原来的代码,使用的虚拟主机的模式进行操作.几个相关的网站放在一个文件里,想法是通过网站列出的目录进行相应的网站进行操作.一切设置完成后,在浏览器中运行出现在You don't ...

  2. navicat for mysql无法连接数据库和连接数据库慢的问题

    首先在自己虚拟机上登录mysql: mysql -uroot -p 然后赋予权限 GRANT ALL PRIVILEGES ON *.* TO root@'%' IDENTIFIED BY '1234 ...

  3. Ruby环境搭建

    刚接触Ruby,发现Ruby真心强大,搞了那么久的Java了,已经被Java的繁琐的语法整的无语透顶了,尤其的Java异常,设计出来就是个失败呀!Ruby目前更新到了2.x了,社区也很活跃,开发效率和 ...

  4. zabbix问题汇总

    1. ::110809.577 resuming IPMI checks on host [10.1.3.41]: connection restored :: seconds :: seconds ...

  5. 双向数据绑定实现之Object.defineProperty

    vue.js利用的是es5的 defineproperty 特性实现的双向数据绑定,了解一下基本原理. 举例 var person= {}; Object.defineProperty(person, ...

  6. generatorConfiguration配置文件及其详细解读

    <?xml version="1.0" encoding="UTF-8" ?> <!DOCTYPE generatorConfiguratio ...

  7. http基础(1.了解web及网络基础,2.简单的http协议)

    第一章:了解web及网络基础 1.http:超文本传输协议 2.tcp/ip协议族:通常使用的网络是在tcp/ip协议族的基础上运作的,而http属于它内部的一个子集. 3.tcp/ip协议族按层次分 ...

  8. OScached缓存整个页面和缓存局部页面

    1.缓存整个页面 在OSCache组件中提供了一个CacheFilter用于实现页面级的缓存.主要用于对web应用中的某些动态页面进行缓存,尤其是那些需要生成PDF格式文件/报表.图片文件等的页面,不 ...

  9. 【hdu5381】维护区间内所有子区间的gcd之和-线段树

    题意:给定n个数,m个询问,每次询问一个区间内所有连续子区间的gcd的和.n,m<=10^5 题解: 这题和之前比赛的一题很像.我们从小到大枚举r,固定右端点枚举左端点,维护的区间最多只有log ...

  10. 【poj2182】【poj2828】树状数组/线段树经典模型:逆序查找-空位插入法

    poj2182题意:有一个1~n的排列,现在给定每个人前面有多少个人的编号比他大,求这个排列是什么.n<=8000 poj2182题解: 逆序做,可以确定二分最后一个是什么,然后删除这个数.树状 ...