7.Redis常用命令:ZSet
Sorted-Sets和Sets类型极为相似,它们都是字符串的集合,都不允许重复的成员出现在一个Set中。它们之间的主要差别是Sorted-Sets中的每一个成员都会有一个分数(score)与之关联,Redis正是通过分数来为集合中的成员进行从小到大的排序。然而需要额外指出的是,尽管Sorted-Sets中的成员必须是唯一的,但是分数(score)却是可以重复的。
在Sorted-Set中添加、删除或更新一个成员都是非常快速的操作,其时间复杂度为集合中成员数量的对数。由于Sorted-Sets中的成员在集合中的位置是有序的,因此,即便是访问位于集合中部的成员也仍然是非常高效的。事实上,Redis所具有的这一特征在很多其它类型的数据库中是很难实现的,换句话说,在该点上要想达到和Redis同样的高效,在其它数据库中进行建模是非常困难的。
1、ZADD key score member [score] [member]
增加多个成员
127.0.0.1:> zadd CountryPower America China Russia Brazil Japan
(integer)
127.0.0.1:> zrange CountryPower - withscores
) "Brazil"
) ""
) "Japan"
) ""
) "China"
) ""
) "Russia"
) ""
) "America"
) ""
2、ZREM key member [member ...]
该命令将移除参数中指定的成员,其中不存在的成员将被忽略。
127.0.0.1:> zrange CountryPower - withscores
) "Brazil"
) ""
) "Japan"
) ""
) "China"
) ""
) "Russia"
) ""
) "America"
) ""
127.0.0.1:> zrem CountryPower Brazil Japan
(integer)
127.0.0.1:> zrange CountryPower - withscores
) "China"
) ""
) "Russia"
) ""
) "America"
) ""
3、ZINCRBY key increment member
为key中的member加指定分数(increment)
127.0.0.1:> zrange CountryPower - withscores
) "China"
) ""
) "Russia"
) ""
) "America"
) ""
127.0.0.1:> zincrby CountryPower China //为中国增加5点
""
127.0.0.1:> zrange CountryPower - withscores
) "China"
) ""
) "Russia"
) ""
) "America"
) ""
4、ZSCORE key member
获取指定Key的指定成员的分数
127.0.0.1:> zrange CountryPower - withscores
) "China"
) ""
) "Russia"
) ""
) "America"
) ""
127.0.0.1:> zscore CountryPower China
""
5、ZRANK key member
返回成员在列表中的下标
127.0.0.1:> zrange CountryPower - withscores
) "China"
) ""
) "Russia"
) ""
) "America"
) ""
127.0.0.1:> zrank CountryPower Russia
(integer)
6、ZREVRANK key member
该命令的功能和ZRANK基本相同,唯一的差别在于该命令获取的索引是从高到低排序后的位置,同样0表示第一个元素,即分数最高的成员。
127.0.0.1:> zrange CountryPower - withscores
) "China"
) ""
) "Russia"
) ""
) "America"
) ""
127.0.0.1:> zrank CountryPower America
(integer)
127.0.0.1:> zrevrank CountryPower America
(integer)
7、ZCARD key
成员数量
127.0.0.1:> zrange CountryPower - withscores
) "China"
) ""
) "Russia"
) ""
) "America"
) ""
127.0.0.1:> zcard CountryPower
(integer)
8、ZCOUNT key min max
计算分数在min与max之间的成员数量。针对min和max参数需要额外说明的是,-inf和+inf分别表示Sorted-Sets中分数的最高值和最低值。缺省情况下,min和max表示的范围是闭区间范围,即min <= score <= max内的成员将被返回。然而我们可以通过在min和max的前面添加"("字符来表示开区间,如(min max表示min < score <= max,而(min (max表示min < score < max。
127.0.0.1:> zrange CountryPower - withscores
) "France"
) ""
) "German"
) ""
) "Japan"
) ""
) "China"
) ""
) "Russia"
) ""
) "America"
) ""
127.0.0.1:> zcount CountryPower +inf //从90分到最高分
(integer)
127.0.0.1:> zcount CountryPower -inf //从最低分到90分
(integer)
127.0.0.1:> zcount CountryPower //从85分(包含)到89分(包含)
(integer)
127.0.0.1:> zcount CountryPower ( ( //从85分(不包含)到89分(不包含)
(integer)
---------------------- 范围筛选 ----------------------
9、ZRANGE key start stop [WITHSCORES]
截取范围内的成员(自选带分数)
127.0.0.1:> zrange CountryPower - withscores
) "France"
) ""
) "German"
) ""
) "Japan"
) ""
) "China"
) ""
) "Russia"
) ""
) "America"
) ""
10、ZREVRANGE key start stop [WITHSCORES]
该命令的功能和ZRANGE基本相同,唯一的差别在于该命令是通过反向排序获取指定位置的成员,即从高到低的顺序。
127.0.0.1:> zrevrange CountryPower - withscores
) "America"
) ""
) "Russia"
) ""
) "China"
) ""
) "Japan"
) ""
) "German"
) ""
) "France"
) ""
11、ZRANGEBYSCORE key min max [WITHSCORES] [LIMIT offset count]
返回分数满足表达式min <= score <= max的成员,其中返回的成员是按照其分数从低到高的顺序返回,如果成员具有相同的分数,则按成员的字典顺序返回。LIMIT用于限制返回成员的数量范围。可选参数offset表示从符合条件的第offset个成员开始返回,同时返回count个成员。参数中min和max的规则可参照命令ZCOUNT
127.0.0.1:> zrevrange CountryPower - withscores
) "America"
) ""
) "Russia"
) ""
) "China"
) ""
) "Japan"
) ""
) "German"
) ""
) "France"
) ""
127.0.0.1:> zrangebyscore CountryPower withscores //95 97 99
) "China"
) ""
) "Russia"
) ""
) "America"
) ""
127.0.0.1:> zrangebyscore CountryPower withscores limit //从取得的结果,从下标为1开始取,取2个
) "Russia"
) ""
) "America"
) ""
12、ZREVRANGEBYSCORE key max min [WITHSCORES] [LIMIT offset count]
该命令除了排序方式是基于从高到低的分数排序之外,其它功能和参数含义均与ZRANGEBYSCORE相同。
127.0.0.1:> zrevrangebyscore CountryPower withscores
) "America"
) ""
) "Russia"
) ""
) "China"
) ""
127.0.0.1:> zrevrangebyscore CountryPower withscores limit
) "America"
) ""
) "Russia"
) ""
------------- 批量删除 -------------
13、ZREMRANGEBYRANK key start stop
删除索引位置位于start和stop之间的成员,start和stop都是0-based,即0表示分数最低的成员,-1表示最后一个成员,即分数最高的成员。
127.0.0.1:> zrange CountryPower - withscores
) "France"
) ""
) "German"
) ""
) "Japan"
) ""
) "China"
) ""
) "Russia"
) ""
) "America"
) ""
127.0.0.1:> zremrangebyrank CountryPower
(integer)
127.0.0.1:> zrange CountryPower - withscores
) "Japan"
) ""
) "China"
) ""
) "Russia"
) ""
) "America"
) ""
14、ZREMRANGEBYSCORE key min max
删除分数在min和max之间的所有成员,即满足表达式min <= score <= max的所有成员。对于min和max参数,可以采用开区间的方式表示,具体规则参照ZCOUNT。
127.0.0.1:> zrange CountryPower - withscores
) "Japan"
) ""
) "China"
) ""
) "Russia"
) ""
) "America"
) ""
127.0.0.1:> zremrangebyscore CountryPower -inf //删除95分(含)以下的
(integer)
127.0.0.1:> zrange CountryPower - withscores
) "Russia"
) ""
) "America"
) ""
7.Redis常用命令:ZSet的更多相关文章
- Redis常用命令
Redis常用命令Redis提供了丰富的命令对数据库和各种数据类型进行操作,这些命令可以再Linux终端使用.1.键值相关命令2.服务器相关命令 一.键值相关命令 1.get get 键值 当 key ...
- 第2讲 Redis常用命令与高级应用
目录 一.redis数据类型 5. sorted sets类型和操作 二.Redis常用命令 1.键值相关命令 2.服务器相关命令 三. redis高级应用 1. 给redis服务器设置密码 2.持久 ...
- Redis常用命令与高级应用
附: 127.0.0.1:6379> set xiaofei 小飞 OK 127.0.0.1:6379> get xiaofei "\xe5\xb0\x8f\xe9\xa3\x9 ...
- Redis快速起步及Redis常用命令大全
本系列教程内容提要 Java工程师之Redis实战系列教程教程是一个学习教程,是关于Java工程师的Redis知识的实战系列教程,本系列教程均以解决特定问题为目标,使用Redis快速解决在实际生产中的 ...
- Redis常用命令手册:服务器相关命令
Redis提供了丰富的命令(command)对数据库和各种数据类型进行操作,这些command可以在Linux终端使用.在编程时,比如各类语言包,这些命令都有对应的方法.下面将Redis提供的命令做一 ...
- redis redis常用命令及内存分析总结(附RedisClient工具简介
redis常用命令及内存分析总结(附RedisClient工具简介 by:授客 QQ:1033553122 redis-cli工具 查看帮助 连接redis数据库 常用命令 exists key se ...
- redis配置密码 redis常用命令
redis配置密码 1.通过配置文件进行配置yum方式安装的redis配置文件通常在/etc/redis.conf中,打开配置文件找到 [plain] view plain copy #requi ...
- redis常用命令及持久化机制
redis 常用命令 查找redis服务文件 find / -name redis-server 查找配置文件 find / -name redis.conf 启动服务时候,要指定配置文件 启动r ...
- Redis 常用命令 大全
Redis 常用命令 发现几个很好的 Redis 常用命令汇总大全网页,分享给小伙伴们~ 1.Redis 命令参考 http://redisdoc.com/string/index.html 2.W3 ...
- No-sql之redis常用命令
转自:http://blog.csdn.net/nicewuranran/article/details/51793760 No-SQL之Redis 介绍 Redis是一种基于内存存储的key-val ...
随机推荐
- BZOJ1115:[POI2009]石子游戏Kam(博弈论)
挺水的 听说是阶梯nim和,就去看了一下,然后就会了= = 观察题目,发现拿第i堆棋子k个造成的影响就是第i+1堆棋子能多拿k个 可以把模型转化为,有n堆石子,每次从某一堆拿一个石子,放在下一堆中,不 ...
- 理解WEB API网关
*:first-child { margin-top: 0 !important; } body>*:last-child { margin-bottom: 0 !important; } /* ...
- 前端学PHP之日期与时间
前面的话 在Web程序开发时,时间发挥着重要的作用,不仅在数据存储和显示时需要日期和时间的参与,好多功能模块的开发,时间通常都是至关重要的.网页静态化需要判断缓存时间.页面访问消耗的时间需要计算.根据 ...
- 使用 Bitbucket Pipelines 持续交付托管项目
简介 Bitbucket Pipelines 是Atlassian公司为Bitbucket Cloud产品添加的一个新功能, 它为托管在Bitbucket上的项目提供了一个良好的持续集成/交付的服务. ...
- 利用jink的驱动软件j-flash 合并两个hex的方法,bootloader+app
由于前几天要给工厂app和bootloader的hex的文件,网上很多都是bin的合并方法,bin的方法不再赘述,相信大家都能找到,现在将hex合并的方法写下来: 第一步:先打开第一个hex文件, 第 ...
- tmux进阶之tmuxinator
tmux进阶之tmuxinator 作者:crane-yuan 日期:2017-03-03 前言 tmuxinator是tmux的配置管理工具,解决了tmux服务器关机后session丢失问题.tmu ...
- UCSC genome browser 个人track 安装
处理基因组数据,很多时候我们会觉得直接看序列文件不够直观,如果绘图的话,把n多G把数据用画图出来不仅费劲,就算操作也不方便.因此我们可以用UCSC开发出的genome browser,可以直接把数据信 ...
- Spring框架(6)---AspectJ实现AOP
AspectJ实现AOP 上一篇文章Spring框架(4)---AOP讲解铺垫,讲了一些基础AOP理解性的东西,那么这篇文章真正开始讲解AOP 通过AspectJ实现AOP要比普通的实现Aop要方便的 ...
- 3384/1750: [Usaco2004 Nov]Apple Catching 接苹果
3384/1750: [Usaco2004 Nov]Apple Catching 接苹果 Time Limit: 1 Sec Memory Limit: 128 MBSubmit: 18 Solv ...
- .进程&线程(&java.lang.Thread)详解
一.进程与线程 进程 我们在进行操作电脑的时候,通常会打开浏览器,通讯工具等应用程序,这个时候CPU通过作业调度在内存中就会分配一些空间让它们处于宏观上的运行状态(处于可以被CPU执行的状态),而这部 ...