Redis常用命令入门5:有序集合类型
有序集合类型
上节我们一起学习了集合类型,感受到了redis的强大。现在我们接着学Redis的最后一个类型——有序集合类型。
有序集合类型,大家从名字上应该就可以知道,实际上就是在集合类型上加了个有序而已。Redis中的有序集合类型,实际上是在集合类型上,为每个元素都关联一个分数,有序实际上说的是分数有序,我们根据分数的范围获取集合及其他操作。集合的元素依然是不能够相同的,但是分数可以相同。
下面列举有序集合和类型和列表类型的相似处:
①两者都是有序的(废话!)
②两者都可以获得某一范围的元素
下面列举区别:
①列表是链表实现的,靠近两边的数据读取极快,而元素过多后获取中间元素的速度则会很慢;有序集合类型使用的散列表和跳跃表(Skip list)实现的,所以读取哪部分的数据都差不多(时间复杂度是O(logN))。
②列表中不能简单的调整元素的位置,但是有序集合可以(通过改变分数)。
③有序集合比列表费内存(要存储分数、散列、跳跃表)。
下面我们来一起学习命令(这里参数关键字都比较多,所以下面开始列举的命令,关键字都使用大写)。
1、增加元素
ZADD key score member [score member ...]
ZADD命令是向集合中增加元素的命令,往集合中增加分数为score的member,这里也是可以一次增加多个值,返回值是成功增加的元素的个数,如果member存在,则score会覆盖原有的分数。
127.0.0.1:> zadd scoreboard tom
(integer) 1 //添加一个
127.0.0.1:> zadd scoreboard peter david
(integer) 2 //添加多个
127.0.0.1:> zrange scoreboard - withscores
) "peter" //带分数输出
) ""
) "tom"
) ""
) "david"
) ""
我们发现Peter的分数录入错了,需要修改为76分,这时候我们接着执行下面的命令。
127.0.0.1:> zadd scoreboard peter
(integer) 0 //member存在时,score不一致,会修改score
127.0.0.1:> zrange scoreboard - withscores
) "peter"
) "" //70->76
) "tom"
) ""
) "david"
) ""
这里分数不仅仅支持整数,还支持浮点数。
127.0.0.1:> zadd testscore 17e+ A
(integer)
127.0.0.1:> zadd testscore 3.3 B
(integer)
127.0.0.1:> zadd testscore -inf D
(integer)
127.0.0.1:> zadd testscore +inf C
(integer)
127.0.0.1:> zrange testscore - withscores
) "D"
) "-inf"
) "B"
) "3.2999999999999998"
) "A"
) "1.6999999999999999e+308"
) "C"
) "inf"
其中+inf和-inf是正负无穷的意思。
2、获得元素的分数
127.0.0.1:> zscore scoreboard peter
""
3、获得排名在某个范围的元素列表
ZRANGE命令会按照元素分数的从小到大顺序返回索引从start到stop之间所有的元素(包含两端)。ZRANGE与LRANGE命令相似,索引从0开始,负数一样代表从后向前查找(-1是最后一个)。WITHSCORE代表是否加上分数。
127.0.0.1:> zrange scoreboard
) "peter"
) "tom"
) "david"
127.0.0.1:> zrange scoreboard - withscores
) "peter"
) ""
) "tom"
) ""
) "david"
) ""
127.0.0.1:> zrevrange scoreboard - withscores
) "david"
) ""
) "tom"
) ""
) "peter"
) ""
ZRANGE命令的时间复杂度为O(longN+m),其中n为有序集合的基数,m为返回的元素个数。如果遇到分数相同的情况,Redis会按照字典顺序(即”0″<…<”9″<”A”<…<”Z”<”a”<…<”z”这样的顺序)进行排列。如果是中文,也会按照编码之后的字典顺序排序。
ZREVRANGE命令和ZRANGE命令唯一不同的是ZREVRANGE命令是按照分数从大到小给出顺序结果。
4、获得指定分数范围的元素
这个命令参数很多,但是都很好理解。这个命令用来获取指定分数范围的元素,min是最小值,max是最大值,WITHSCORE还是和上面介绍的一样,LIMIT是为了指定偏移量及数量的,和sql的有点像。offset是偏移量,count是数量。同时这些min和max都是包含的,如果要想不包含,需要使用“(”符号。
127.0.0.1:> zrangebyscore scoreboard withscores
) "tom"
) ""
) "david"
) ""
127.0.0.1:> zrangebyscore scoreboard ( withscores
) "tom"
) ""
) "david"
) ""
127.0.0.1:> zrangebyscore scoreboard ( withscores
) "tom"
) ""
127.0.0.1:> zrangebyscore scoreboard withscores limit
) "david"
) ""
127.0.0.1:> zrangebyscore scoreboard withscores limit
) "david"
) ""
127.0.0.1:> zrangebyscore scoreboard +inf withscores
) "peter"
) ""
) "tom"
) ""
) "david"
) ""
5、增加某个元素的分数
127.0.0.1:> ZINCRBY scoreboard peter
""
127.0.0.1:> ZINCRBY scoreboard - peter
""
这个命令可以增加一个元素的分数,返回值是更改后的分数。这里就不再赘述用法了,和INCRBY命令类似。同样如果不存在会初始为0在增加,负数即是减小。
6、获得集合中元素的数量
这个命令和SCARD类似,也就不多说了。
7、获得指定分数范围的元素个数
这里就是获得min和max分数之间的元素数,当然这里也支持“(”符号。
8、删除一个或多个元素
返回值是成功删除的元素的个数。
127.0.0.1:> zrem scoreboard peter
(integer)
127.0.0.1:> zrange scoreboard -
) "tom"
) "david"
9、按照排名范围删除元素
这个命令按照元素分数从小到大顺序删除指定范围内所有的元素(其实就是先排序,然后按照排好的序列的索引删除),并返回删除的元素的数量。
10、按照分数范围删除元素
这里就是直接删除分数范围的元素了,这里分数同样支持“(”符号,返回删除数量。
11、获得元素的排名
ZRANK命令按照元素分数的从小到大的顺序获得制定元素的排名(第一个从0开始),ZREVRANK则相反。
127.0.0.1:> zrank scoreboard tom
(integer)
127.0.0.1:> zrank scoreboard david
(integer)
最后我们举个实际应用的例子。
我们把wordpress的文章按点击率排序,关系数据库我们是遍历所有的文章排序点击数,如果使用Redis,我们需要一个posts:page.view键的有序集合类型,然后每个member为文章ID,score为文章的点击量。这样我们就可以用ZREVRANGE命令获取点击量排行榜。
还有一个实际的例子,我们用有序集合类型保存文章的发布时间(时间用UNIX时间及时间的毫秒数)与文章ID,这样我们可以很方便的按时间来查看文章列表,我们的文章列表应该是用文章发布时间排序而不应该用文章ID排序的。
Redis常用命令入门5:有序集合类型的更多相关文章
- Redis常用命令入门4:集合类型
集合类型 之前我们已经介绍过了最基本的字符串类型.散列类型.列表类型,下面我们一起学习一下集合类型. 集合类型也是体现redis一个比较高价值的一个类型了.因为Redis的集合类型,所以我们可以很容易 ...
- Redis常用命令入门1:字符串类型命令
Redis总共有五种数据类型,在学习的时候,一定要开一个redis-cli程序,边看边练,提高效率. 一.最简单的命令 1.获得符合规则的键名列表 keys * 这里的*号,是指列出所有的键,同时*号 ...
- Redis常用命令入门3:列表类型
列表类型 列表类型也是一个我们很长要用到的一个类型.比如我们发博客,要用到博客列表.如果没有列表我们就只能遍历键来获取所有文章或一部分文章了,这个语法是keys,但是这个命令需要遍历数据库中的所有键, ...
- Redis 常用命令学四:集合类型命令
1.增加和删除命令 127.0.0.1:6379> SADD st a (integer) 1 127.0.0.1:6379> SADD st r f g (integer) 3 127. ...
- Redis常用命令入门2:散列类型
散列命令 散列类型的键值其实也是一种字典解耦,其存储了字段和字段值的映射,但字段值只能是字符串,不支持其他数据类型,所以说散列类型不能嵌套其他的数据类型.一个散列类型的键可以包含最多2的32次方-1个 ...
- Redis常用命令入门——列表类型(一级二级缓存技术)
获取列表片段 redis > LRANGE KEY_NAME START END lrange命令比较常用,返回从start到stop的所有元素的列表,start和stop都是从0开始. (1) ...
- Redis常用操作--------SortedSet(有序集合)
1.ZADD key score member [[score member] [score member] ...] 将一个或多个 member 元素及其 score 值加入到有序集 key 当中. ...
- Redis 常用命令学习二:字符串类型命令
1.赋值与取值命令 127.0.0.1:6379> set foo helloredis OK 127.0.0.1:6379> get foo "helloredis" ...
- Redis 常用命令学四:列表类型命令
1.在列表两端增加值的命令 127.0.0.1:6379> lpush 1 (error) ERR wrong number of arguments for 'lpush' command 1 ...
随机推荐
- MongoDB由于目标计算机积极拒绝,无法连接
遇到这个问题的时候,可以通过以下步骤解决: 1.打开Mongo安装包:进入Mongo下的data文件夹下的db文件夹,找到Mongod.lock,删除. 2.在命令行中输入: mongod.exe - ...
- 用STM32CubeMX创建FreeRTOS项目
1. 目标, PG13,PG14双线程双闪灯. 2. 测试平台 stm32f429i-disco keil v5.13.0.0 CubeMx 4.8.0 3. 步骤 3.1 打开cube, PG13, ...
- libevent源码分析:eventop
eventop:定义了event_base使用的后端IO复用的一个统一接口 /** Structure to define the backend of a given event_base. */ ...
- Life is short
相信不少码农曾看过类似“life is short, use Python”等之类略带调侃意味的小段子(譬如我),而其也并非不无道理.每门编程语言都是合理的存在,都有它们的优点,及缺陷. 码农们也大多 ...
- String高效编程优化(Java)
1, substring截取超大字符串可能造成的“内存泄漏” 2,+ 操作符的优化和局限 3,StringBuilder和StringBuffer 4,split和StringTokenizer做简单 ...
- Java进行post和get传参数
http://www.cnblogs.com/zhuawang/archive/2012/12/08/2809380.html get和post方法 import java.io.BufferedRe ...
- 在Excel中制作复合饼图
在Excel中插入饼图时有时会遇到这种情况,饼图中的一些数值具有较小的百分比,将其放到同一个饼图中难以看清这些数据,这时使用复合条饼图就可以提高小百分比的可读性. 文中的复合饼图只是方便以后记忆,故不 ...
- 《Spring MVC学习指南》怎么样?答:书名具有很大的欺骗性
2016年6月21日 最近,因为工作需要,我从网上买了一本<Spring MVC学习指南>,ISBN编号: 978-7-115-38639-7,定价:49.00元.此书是[美]Paul D ...
- CFNetwork的错误代码参考
所有的错误代码是在对“CFNetwork的错误代码参考” 小提取CFURL和CFURLConnection错误: kCFURLErrorUnknown = -998, kCFURLErrorCance ...
- Mac上配置Privoxy
此文档适用于走Shadowsocks代理,想利用Privoxy将主机作为代理服务器的用户. 0.安装完Privoxy后,打开终端命令. 1.打开Privoxy的配置文件config: cd /usr/ ...