Redis的sorted set类型
Redis 有序集合命令
下表列出了 redis 有序集合的基本命令:
序号 | 命令及描述 |
---|---|
1 |
ZADD key score1 member1 [score2 member2] 向有序集合添加一个或多个成员,或者更新已存在成员的分数 |
2 |
ZCARD key 获取有序集合的成员数 |
3 |
ZCOUNT key min max 计算在有序集合中指定区间分数的成员数 |
4 |
ZINCRBY key increment member 有序集合中对指定成员的分数加上增量 increment |
5 |
ZINTERSTORE destination numkeys key [key ...] 计算给定的一个或多个有序集的交集并将结果集存储在新的有序集合 key 中 |
6 |
ZLEXCOUNT key min max 在有序集合中计算指定字典区间内成员数量 |
7 |
ZRANGE key start stop [WITHSCORES] 通过索引区间返回有序集合指定区间内的成员 |
8 |
ZRANGEBYLEX key min max [LIMIT offset count] 通过字典区间返回有序集合的成员 |
9 |
ZRANGEBYSCORE key min max [WITHSCORES] [LIMIT] 通过分数返回有序集合指定区间内的成员 |
10 |
ZRANK key member 返回有序集合中指定成员的索引 |
11 |
ZREM key member [member ...] 移除有序集合中的一个或多个成员 |
12 |
ZREMRANGEBYLEX key min max 移除有序集合中给定的字典区间的所有成员 |
13 |
ZREMRANGEBYRANK key start stop 移除有序集合中给定的排名区间的所有成员 |
14 |
ZREMRANGEBYSCORE key min max 移除有序集合中给定的分数区间的所有成员 |
15 |
ZREVRANGE key start stop [WITHSCORES] 返回有序集中指定区间内的成员,通过索引,分数从高到低 |
16 |
ZREVRANGEBYSCORE key max min [WITHSCORES] 返回有序集中指定分数区间内的成员,分数从高到低排序 |
17 |
ZREVRANK key member 返回有序集合中指定成员的排名,有序集成员按分数值递减(从大到小)排序 |
18 |
ZSCORE key member 返回有序集中,成员的分数值 |
19 |
ZUNIONSTORE destination numkeys key [key ...] 计算给定的一个或多个有序集的并集,并存储在新的 key 中 |
20 |
ZSCAN key cursor [MATCH pattern] [COUNT count] |
127.0.0.1:6379> zadd scores 94 zs 100 ls (integer) 2 127.0.0.1:6379> zdd scores 60 ww 47 zl (error) ERR unknown command `zdd`, with args beginning with: `scores`, `60`, `ww`, `47`, `zl`, 127.0.0.1:6379> zadd scores 60 ww 47 zl (integer) 2 127.0.0.1:6379> ZRANGE scores 0 -1 1) "zl" 2) "ww" 3) "zs" 4) "ls" 127.0.0.1:6379> ZREVRANGE scores 0 -1 1) "ls" 2) "zs" 3) "ww" 4) "zl" 127.0.0.1:6379> ZRANGE scores 0 -1 withscores 1) "zl" 2) "47" 3) "ww" 4) "60" 5) "zs" 6) "94" 7) "ls" 8) "100" 127.0.0.1:6379> ZREM scores ww (integer) 1 127.0.0.1:6379> ZREVRANGE scores 0 -1 1) "ls" 2) "zs" 3) "zl" 127.0.0.1:6379> ZRANGEBYSCORE scores 50 80 withscores (empty list or set) 127.0.0.1:6379> ZRANGEBYSCORE scores 40 80 withscores 1) "zl" 2) "47" 127.0.0.1:6379> ZRANGEBYSCORE scores 40 100 withscores limit 1 (error) ERR syntax error 127.0.0.1:6379> ZRANGEBYSCORE scores 40 100 withscores limit 0 1 1) "zl" 2) "47" 127.0.0.1:6379> ZRANGEBYSCORE scores 40 100 withscores limit 0 2 1) "zl" 2) "47" 3) "zs" 4) "94" 127.0.0.1:6379> ZREMRANGEBYRANK scores 0 0 (integer) 1 127.0.0.1:6379> ZRANGE scores 0 -1 withscores 1) "zs" 2) "94" 3) "ls" 4) "100" 127.0.0.1:6379> ZCARD scores (integer) 2 127.0.0.1:6379> ZCOUNT scores 90 99 (integer) 1 127.0.0.1:6379> zadd s1 50 aa 60 bb 70 cc (error) WRONGTYPE Operation against a key holding the wrong kind of value 127.0.0.1:6379> zadd s 50 aa 60 bb 70 cc (integer) 3 127.0.0.1:6379> zadd s1 50 aa 70 bb (error) WRONGTYPE Operation against a key holding the wrong kind of value 127.0.0.1:6379> zadd ss 50 aa 70 bb (integer) 2 127.0.0.1:6379> ZINTERSTORE sss 2 s ss (integer) 2 127.0.0.1:6379> ZRANGE sss 0 -1 withscores 1) "aa" 2) "100" 3) "bb" 4) "130" 127.0.0.1:6379> ZINTERSTORE de
业务场景
票选广东十大杰出青年,各类综艺选秀海选投票各类资源网站TOP10(电影,歌曲,文档,电商,游戏等)
聊天室活跃度统计
游戏好友亲密度
127.0.0.1:6379> ZADD movies 143 aa 97 bb 200 cc (integer) 3 127.0.0.1:6379> ZRAnk movies bb (integer) 0 127.0.0.1:6379> ZRAnk movies cc (integer) 2 127.0.0.1:6379> ZREVRANk movies bb (integer) 2 127.0.0.1:6379> ZSCORE movies aa "143" 127.0.0.1:6379> ZINCRBY movies 1 aa "144" 127.0.0.1:6379> ZSCORE movies aa "144" 127.0.0.1:6379>
业务场景
基础服务+增值服务类网站会设定各位会员的试用,让用户充分体验会员优势。例如观影试用VIP、游戏
VIP体验、云盘下载体验VIP、数据查看体验VIP。当VIP体验到期后,如果有效管理此类信息。即便对于正式
VIP用户也存在对应的管理方式。
网站会定期开启投票、讨论,限时进行,逾期作废。如何有效管理此类过期信息。
127.0.0.1:6379> zadd tx 19021090 uid:001 (integer) 1 127.0.0.1:6379> zadd tx 19234290 uid:007 (integer) 1 127.0.0.1:6379> zadd tx 1923429083 uid:008 (integer) 1 127.0.0.1:6379> zrange tx 0 -1 withscores 1) "uid:001" 2) "19021090" 3) "uid:007" 4) "19234290" 5) "uid:008" 6) "1923429083" 127.0.0.1:6379> time 1) "1584619821" 2) "452034" 127.0.0.1:6379>
业务场景
任务/消息权重设定应用
当任务或者消息待处理,形成了任务队列或消息队列时,对于高优先级的任务要保障对其优先处理,如
何实现任务权重管理。
127.0.0.1:6379> ZADD tasks 4 order:id:001 (integer) 1 127.0.0.1:6379> ZADD tasks 1 order:id:002 (integer) 1 127.0.0.1:6379> ZADD tasks 9 order:id:003 (integer) 1 127.0.0.1:6379> ZREVRANGE task 0 -1 withscores (empty list or set) 127.0.0.1:6379> 127.0.0.1:6379> ZREVRANGE tasks 0 -1 withscores 1) "order:id:003" 2) "9" 3) "order:id:001" 4) "4" 5) "order:id:002" 6) "1" 127.0.0.1:6379> ZREVRANGE tasks 0 0 1) "order:id:003" 127.0.0.1:6379> ZREM tasks order:id:003 (integer) 1 127.0.0.1:6379> ZREVRANGE tasks 0 -1 withscores 1) "order:id:001" 2) "4" 3) "order:id:002" 4) "1" 127.0.0.1:6379>
sorted_set 类型数据操作的注意事项
score保存的数据存储空间是64位,如果是整数范围是-9007199254740992~9007199254740992
score保存的数据也可以是一个双精度的double值,基于双精度浮点数的特征,可能会丢失精度,使用时候要慎重
sorted_set 底层存储还是基于set结构的,因此数据不能重复,如果重复添加相同的数据,score值将被反复覆盖,保留最后一次修改的结果
Redis的sorted set类型相关推荐
- redis之sorted sets类型及操作
sorted sets类型及操作 sorted set是set的一个升级版本,它在set的基础上增加了一个顺序属性,这一属性在添加修改元素的时候可以指定,每次指定后,zset会自动重新按新的值调整顺序 ...
- Redis 笔记(07)— sorted set 类型(添加、删除有序集合元素、获取分数范围内成员、按score排序、返回集合元素个数)
zset 可能是 Redis 提供的最为特色的数据结构,一方面它是一个 set,保证了内部 value 的唯一性,另一方面它可以给每个 value 赋予一个 score,代表这个 value 的排序权 ...
- Redis sorted set 类型操作及常用命令
七个原则 Redis 是一个操作数据结构的语言工具,它提供基于 TCP 的协议以操作丰富的数据结构.在 Redis 中,数据结构这个词的意义不仅表示在某种数据结构上的操作,更包括了结构本身及这些操作的 ...
- Redis中对ZSet类型的操作命令
写在前面的话:读书破万卷,编码如有神 -------------------------------------------------------------------- ------------ ...
- Redis工作笔记-Hash类型
目录 概述 操作 概述 Redis中的Hash类型看成具有String Key和String Value的map容器.所以该类型非常适合于存储键值对象的信息.如Username.Password和Ag ...
- java使用redis incr,JFinal Redis plugin 有关数值类型incr操作的bug
先上测试代码:public class TestCache { private static final Cache testCache = Redis.use(CacheCons.TEST) ; p ...
- 系统学习redis之五——redis数据类型之list类型及操作
list数据类型介绍 list是一个链表结构,主要功能是push.pop.获取一个范围的所有值等等,操作中key可以理解为链表的名字.redis的list类型其实就是一个每个子元素都是string类型 ...
- zset获取指定score_7、Redis中对ZSet类型的操作命令
写在前面的话:读书破万卷,编码如有神 -------------------------------------------------------------------- ------------ ...
- 利用 Redis 的 sorted set 做每周热评的功能
大概思路 思路分析 做每周热议,应该用缓存来做,如果直接查库的话,会对数据库造成压力.用缓存做的话,用Redis 来做缓存的话比较合适一点. 上面的命令可以帮我们记录一下7天的所有的评论数.但是还没有 ...
最新文章
- Flex通过Iframe使用activex控件,点击除Iframe的其他地方后,Iframe内容消失
- 误删Windows文件后恢复技巧
- Python 为了提升性能,竟运用了共享经济
- iOS关于RunLoop和Timer
- Google Hangouts支持使用Firefox WebRTC
- 受困于敏捷开发的数据与架构?肿么办?
- 微软发布首版基于 Chromium 79 的 Edge 浏览器
- 关于重定向printf出错 Error[Pe020]: identifier FILE is undefined 解决方案
- 单片机c语言实验报告心得,关于单片机实训心得体会
- linux进入终端tty3,Linux中终端界面与图形界面之间的切换关系
- 多机联动方案-云真机测试
- vscode中切换远程分支
- js基础 js函数作用域链
- 03 ,n 维向量,向量运算,向量组,向量组的线性组合,基,张成空间,向量组的线性相关性 :
- 惠普g7服务器硬盘阵列,HP DL388 G7 服务器重新做RAID
- nafxcw.lib(dllmodul.obj) : error LNK2005: _DllMain@12 already defined
- C# 动态调整分辨率
- 为什么建议大家使用 Linux 开发?爽++
- TSA-Net论文详解
- 计算机专业助我成长400字作文,坚持伴我成长作文400字(通用10篇)
热门文章
- DOTween充当计时器的小技巧
- 外夹式超声波艾默生流量计安装步骤
- Latex在引用表格和图片时,出现编号错误。
- docker python tool_使用Docker实现Python3.5、Python2.7 在线编程测试执行代码工具-toolfk.com...
- 虚幻引擎图文笔记:蒙太奇(Montage)+ 根运动(Root Motion),给我滚(Roll)!
- 【推荐一款阿里开源的低代码工具,实用性极高!】
- 关于电机双闭环PID控制一些理解
- 麻省理工算法导论(含教材、讲义、答案)
- linux运维培训大纲,Linux运维体系大纲
- 生物-大脑极限:大脑极限