Redis系列六、redis的五种数据结构和相关指令之Sorted Set

本节中将介绍Redis支持的主要数据结构,以及相关的常用Redis命令。redis是一种基于键值对(key-value)的内存数据库,redis数据结构可以分为string、hash、list、set、sorted set。

redis的五种数据结构和相关指令之有序集合sorted set

有序集合sorted set

有序集合与集合一样,元素都不能重复;Sorted Set中的每个元素都需要指派一个分数(score),Sorted Set会根据score对元素进行升序排序。如果多个member拥有相同的score,则以字典序进行升序排序。
常用于排行榜,如视频网站需要对用户上传视频做排行榜,或点赞数与集合有联系,不能有重复的成员。


与LIST和SET对比

 

1、常用命令

 

2、增删指令

添加指令

zadd key [NX|XX] [CH] [INCR] score member [score member…]

XX: 仅仅更新存在的成员,不添加新成员。

NX: 不更新存在的成员。只添加新成员。

CH: 修改返回值为发生变化的成员总数,原始是返回新添加成员的总数 (CH 是 changed 的意思)。更改的元素是新添加的成员,已经存在的成员更新分数。 所以在命令中指定的成员有相同的分数将不被计算在内。注:在通常情况下,ZADD返回值只计算新添加成员的数量,注意: 如果和incr一起使用的时候,返回的会是incr的结果。

INCR: 当ZADD指定这个选项时,成员的操作就等同ZINCRBY命令,对成员的分数进行递增操作。

zadd user:3 200 james //james的点赞数1, 返回操作成功的条数1
zadd user:3 200 james 120 mike 100 lee// 返回3zadd test:1 nx 100 james   //键test:1必须不存在,主用于添加
zadd test:1 xx incr 200 james   //键test:1必须存在,主用于修改,此时为300
zadd test:1 xx ch incr -299 james //返回操作结果1,300-299=1
zrange test:1 0 -1 withscores  //查看点赞(分数)与成员名

增加分数

zincrby user:3 10 lee     //成员lee的分数加10
zadd user:3 xx incr 10 lee //和上面效果一样

删除指令

zrem user:zan jame mike //返回成功删除2个成员,还剩lee


删除指定排名内的升序元素:

zremrangebyrank user:3 0 1 //分数升序排列,删除第0个与第1个,只剩james


删除指定分数范围的成员

zadd user:5 200 james 120 mike 100 lee//先插入测试数据
zremrangebyscore user:5 100 300     //删除分数在100与300范围的成员
zremrangebyscore user:5 (100 +inf    //删除分数大于100(不包括100),还剩lee

3、查看指令

查看分数

zscore user:3 james     //查看james的点赞数(分数),返回200

查看排名

zrank user:3 james  //返回名次:第3名返回2,从0开始到2,共3名
zrevrank user:3 james //返回0, 反排序,点赞数越高,排名越前

返回指定排名范围的分数与成员

zadd user:4 200 james 120 mike 100 lee//先插入数据
zrange user:4 0 -1 withscores //返回结果如下图

zrevrange user:4 0 -1 withscores   //倒序,结果如下图


返回指定分数范围的成员

zrangebyscore user:4 110 300 withscores //返回120 lee ,200 James, 由低到高 
zrevrangebyscore user:4 300 110 withscores //返回200james 120lee,由高到低zrangebyscore user:4 (110 +inf withscores//110到无限大,120mike 200james 
zrevrangebyscore user:4 (110 -inf withscores//无限小到110,返回100 lee

返回指定分数范围的成员个数:

zcount user:4 110 300  //返回2,由mike120和james200两条数据

统计成员数量

zcard test:1     //计算成员个数, 返回1


4、有序集合交集

格式:

zinterstore destination numkeys key ... [WEIGHTS weight] [AGGREGATE SUM|MIN|MAX]

destination:交集产生新的元素存储键名称。
numkeys: 要做交集计算的键个数,匹配不上会有语法错误,会执行不了。
key :元素键值。
weights:每个被选中的键对应值乘weight, 默认为1。
初始化数据:

zadd user:7 1 james 2 mike 4 jack 5 kate      //初始化user:7数据
zadd user:8 3 james 4 mike 4 lucy 2 lee  6 jim  //初始化user:8数据

交集例子:

 zinterstore user_jj 2 user:7 user:8 aggregate sum //2代表键合并个数,
//aggregate sum可加也不可加上,因为默认是sum
//结果user_jj:4james(1+3), 6mike(2+4) zinterstore user_jjmax 2 user:7 user:8 aggregate max 或min 
//取交集最大的分数,返回结果 3james  4mike, min取最小

weights的使用:

zinterstore user_jjweight 2 user:7 user:8 weights 8 4 aggregate max
//1,取两个成员相同的交集,user:7->1 james  2 mike;  user:8->3 james  4 mike
//2,将user:7->james 1*8=8,  user:7->mike 2*8 =16, 最后user:7结果 8 james  16 mike; 
//3,将user:8-> james 3*4=12, user:8->mike 4*4=16,最后user:8结果12 james  16 mike
//4,最终相乘后的结果,取最大值为  12 james 16mike
//5, zrange user_jjweight 0 -1 withscores 查询结果为  12 james 16mike


5、有序集合并集(合并去重)

格式:

zunionstore destination numkeys key ... [WEIGHTS weight] [AGGREGATE SUM|MIN|MAX]

destination:交集产生新的元素存储键名称
numkeys: 要做交集计算的键个数 key :元素键值
weights:每个被选中的键对应值乘weight, 默认为1
eg:

zunionstore user_jjweight2 2 user:7 user:8 weights 8 4 aggregate max
//与以上zinterstore一样,只是取并集,指令一样


6、有序集合应用场景

排行榜系统,如视频网站需要对用户上传的视频做排行榜
点赞数:

zadd user:1:20180106 3 mike  //mike获得3个赞

再获一赞:

zincrby user:1:20180106 1 mike  //在3的基础上加1

用户作弊,将用户从排行榜删掉:

zrem user:1:20180106 mike

展示赞数最多的5个用户:

zrevrangebyrank user:1:20180106  0  4 

查看用户赞数与排名:

zscore user:1:20180106 mike   
zrank user:1:20180106 mike


————————————————
版权声明:本文为CSDN博主「lingengy」的原创文章,遵循CC 4.0 BY-SA版权协议,转载请附上原文出处链接及本声明。
原文链接:https://blog.csdn.net/w1lgy/article/details/84377092

本文来自互联网用户投稿,该文观点仅代表作者本人,不代表本站立场。本站仅提供信息存储空间服务,不拥有所有权,不承担相关法律责任。如若转载,请注明出处:http://www.mzph.cn/news/497431.shtml

如若内容造成侵权/违法违规/事实不符,请联系多彩编程网进行投诉反馈email:809451989@qq.com,一经查实,立即删除!

相关文章

linux内核spi总线驱动分析,Linux下的SPI总线驱动(三)

版权所有,转载请说明转自原创作者:南京邮电大学 通信与信息系统专业 研二 魏清五.SPI测试代码对于SPI总线驱动,我们可以分为SPI控制设备驱动和SPI接口设备驱动。而作为驱动开发人员主要是像SPI移植的时候一样会添加SPI控制设备和…

AI时代的高科技读心术:算法解码脑中图像

来源:科研圈翻译 李杨,审校 张梦茜,编辑 魏潇让我们想象一下:只要在心里浮现出某个人物或风景,就能从一堆数码照片中把它搜索出来。或者不用动笔就能画出一个新的厨房设计。又或者给心爱的人发送一张想象中的落日照…

linux 基础训练题,Linux习题练习

1 在主目录下创建abc文件,并设置其权限为同组用户有执行权限,属主有全部权限,其它用户没有权限。采用chmod命令,数字表示权限,分部是主,组,其他.权限为read,write,execute. 属主有全…

获取字段为List类型中的泛型类型

在java编程时,经常会使用反射去处理对象,有时会需要知道List的泛型类型:示例操作如下 obj pojo.newInstance();// 首先得到pojo所定义的字段Field[] fields pojo.getDeclaredFields();for (Field curField : fields) {// 设置字段可访问&a…

《Nature》发布毫米级软体机器人,可在没有任何物理干预情况下游走于人体

转载自公众号:机器人大讲堂概要:一直以来,微型机器人、软体机器人成为科学研究的热点,我们都期盼机器人能听从指挥的到达人体指定位置,在对人体危害最小的情况下递送药物或者切除病变组织。1966年著名作家艾萨克阿西莫…

Spring Data JPA 禁止自动更新

公司的项目后台架构是SpringBoot Spring Date JPA,采用MySQL数据库。在工作刚开始时就遇到了一个奇怪的现象。在采用Date JPA查询完数据库之后,若改变了查询出的对象属性,那么数据库就会自动更新。比如查询出一个studentPO的name为“小明”&…

Nature:寻找记忆的痕迹

来源:神经科技对于不是《神探夏洛克》超级粉丝的人来说,认知神经科学家Janice Chen对这部英国广播公司的热播侦探剧的了解比大多数人多。当观众观看这部电视剧的第一集然后描述其情节时,Chen能在脑部扫描仪的帮助下监视他们的脑子里正在发生什…

tcl linux 刷 安卓系统,安卓用户看过来—手把手教你刷第三方系统

来来来,小葵花课堂讲课啦。孩子咳嗽老不好,多半是废了,打一顿就好。手机卡顿老不好,先别着急,来刷个机吧。众所周知,因为安卓系统自身的特性,安卓手机用久了难免出现卡顿。一般来说解决的方法有…

DeepMind开源Psychlab平台——搭建AI和认知心理学的桥梁(附论文和代码下载)

来源:专知概要:DeepMind近期开源了Psychlab,这是一个利用认知心理学等领域知识来研究受控环境下人工智能体(Artificial Agent)的行为,从而模拟人类的行为。DeepMind近期开源了Psychlab,这是一个…

linux启动过程剖析,分析Linux系统的启动过程

导读一直使用linux系统,却对系统启动过程及系统初始化和各种服务的启动不太清楚。今天终于搞明白整个是怎么一回事了。本来想自己写篇文章,刚好在网上看到一篇不错的介绍,很详细,就直接拿来了。Linux系统的启动过程:BI…

扩展立方体 The Scale Cube

转自: https://akfpartners.com/growth-blog/scale-cube/ 比例立方体 2018年4月25日| 发布者:Robin McGlothin Scale Cube是用于定义微服务和扩展技术产品的模型。AKF Partners于2007年发明了Scale Cube,最初于2007年在我们的博客上在线发…

人脑动态功能网络连接模式能够鉴别个体并预测其认知功能

来源:神经科技概要:近二十年来,基于静息态功能磁共振影像的人脑连接组学快速发展,为无创研究活体人脑的功能组织规律和网络运作机制提供了重要手段,大大促进了研究者对脑认知、脑发育和脑疾病神经机制的理解。近日&…

linux中dhcp如何配置两个子网,linux – 配置DHCP服务器以在同一VLAN上为多个子网提供服务...

我有一个由多个子网组成的VLAN,我想使用DHCP集中IP地址指定.DHCP服务器(100.100.25.88)是子网100.100.25.64/27上的Debian计算机.我想为子网100.100.68.0/24中的计算机分配IP地址.最终目标是在100.100.68.0/24子网中的所有计算机上启用PXE引导.下面是我的dhcpd.conf文件,# DHCP…

JMS之企业消息传送

企业消息传送:消息是通过网络从一个系统异步传送给其他系统的。 客户端:使用消息传送API 的一个业务应用程序或组件(如:JMS) 集中式体系结构 分散式体系结构

linux看系统硬件,Linux 查看系统硬件信息(实例详解)

cpulscpu命令,查看的是cpu的统计信息.blueblue-pc:~$lscpuArchitecture:i686#cpu架构CPUop-mode(s):32-bit,64-bitByteOrder:LittleEndian#小尾序CPU(s):4#总共cpulscpu命令,,查看的是cpu的统计信息.blueblue-pc:~$ lscpuArchitecture:i686#c…

达沃斯群英纵论人工智能,核心观点汇总

来源:AI科技大本营概要:一年一度的世界经济论坛年会(达沃斯论坛)上,来自不同领域的精英纷纷发表了自己对于人工智能的看法。一年一度的世界经济论坛年会(达沃斯论坛)已经召开了3天,该…

Java消息服务思维导图笔记

https://www.processon.com/view/link/610b5f201efad40724bdfae2

window计算的chk在linux下可以读,Linux系统命令从入门到完全忘记(四)

系统安全相关命令chmod概要:用于改变文件或目录的访问权限,用它控制文件或目录的访问权限。语法格式:chmod [-cfvR] [–help] [–version] mode file参数:参数说明-c当发生改变时,报告处理信息-f错误信息不输出-R处理指…

如何设计一个安全对外的接口

来源:https://mp.weixin.qq.com/s/eDXsqyfIKDXii0DB6W0UcA

三大国有银行同时入股 AI 公司第四范式

来源:新华社概要:人工智能公司第四范式于1月26日宣布完成B+轮融资,并同时宣布获得来自中国工商银行、中国银行、中国建设银行三家国有银行及所属基金的联合战略投资。人工智能公司第四范式于1月26日宣布完成B+轮融资&a…