Redis学习笔记(七)——数据结构之有序集合(sorted set)
一、介绍
Redis有序集合和集合一样都是string类型元素的机会,且不允许重复的成员。
不同的是每个元素都会关联一个double类型的分数。Redis正是通过分数来为集合中的成员进行从小到放大的排序。
有序集合的成员是唯一的,但是分数(score)却可以重复。
集合是通过哈希表实现的,所以添加、删除、查找的复杂度都是O(1)。集合中最大的成员数为4294967295,每个集合可存储40多亿个成员。
基本命令:
- 添加/更新
zadd key score1 member1 [score2 member2 ...] (向有序集合添加一个或多个成员,或者更新已存在成员的分数)
zincrby key increment member (有序集合中对指定成员的分数上增量increment)
zinterstore destination numkeys key [key ...] (计算给定的一个或多个有序集的交集并将结果存储在新的有序集合key中)
- 查询
zcard key (获取有序集合的成员数)
zrange key start stop [withscores] (通过索引区间返回有序集合指定区间内的成员)
zcount key min max (计算在有序集合中指定区间分数的成员数)
zlexcount key min max (在有序集合中计算指定字典区间内成员数量)
zrangebylex key min max [limit offset count] (通过字典区间返回有序集合的成员)
zrangebyscore key min max [withscores] [limit] (通过分数返回有序集合指定区间内的成员)
zrank key member (返回有序集合中指定成员的索引)
zrevrange key start stop [withscores] (返回有序集合中指定区间内的成员,通过索引,分数从高到低)/(反转集合元素)
zrevrangebyscore key max min [withscores] (返回有序集合中指定分数区间内的成员,分数从高到低)
zrevrank key member (返回有序集合中指定成员的排名,有序集合成员按分数值递减,从达到小排序)
zscore key member (返回有序集合中,成员的分数值)
- 移除
zrem key member1 [member2 ...] (移除有序集合中的一个或多个成员)
zremrangebylex key min max (移除有序集合中给定的字典区间的成员)
zremrangebyrank key start stop (移除有序集合中给定的排名区间的成员)
zremrangebyscore key min max (移除有序集合中给定的分数区间的成员)
二、操作
- 添加
1、zadd key score1 member1 [score2 member2 ...] (向有序集合添加一个或多个成员,或者更新已存在成员的分数)
score为分数

2、zincrby key increment member (有序集合中对指定成员的分数上增量increment)
给集合添加一个元素c,分数为0

给元素c增加分数10

结果元素c分数值为10

3、zinterstore destination numkeys key [key ...] (计算给定的一个或多个有序集的交集并将结果存储在新的有序集合key中)
两个集合的元素(可以多个)

计算两个集合的交集并存储到新的集合中(分数值会获取集合中的最大值)

- 查询
1、zcard key (获取有序集合的成员数)

2、zrange key start stop [withscores] (通过索引区间返回有序集合指定区间内的成员)
获取集合所有元素

获取集合所有元素及分数

3、zcount key min max (计算在有序集合中指定区间分数的成员数)

4、zlexcount key min max (在有序集合中计算指定字典区间内成员数量)

5、zrangebylex key min max [limit offset count] (通过字典区间返回有序集合的成员)

6、zrangebyscore key min max [withscores] [limit] (通过分数返回有序集合指定区间内的成员)

7、zrank key member (返回有序集合中指定成员的索引)
如果指定元素(成员)不存在,返回(nil)

8、zrevrange key start stop [withscores] (返回有序集合中指定区间内的成员,通过索引,分数从高到低)/(反转集合元素)
就跟倒序一个道理

9、zrevrangebyscore key max min [withscores] (返回有序集合中指定分数区间内的成员,分数从高到低)

10、zrevrank key member (返回有序集合中指定成员的排名,有序集合成员按分数值递减,从达到小排序)

11、zscore key member (返回有序集合中,成员的分数值)

- 移除
1、zrem key member1 [member2 ...] (移除有序集合中的一个或多个成员)
如果删除的元素不存在返回0

2、zremrangebylex key min max (移除有序集合中给定的字典区间的成员)

3、zremrangebyrank key start stop (移除有序集合中给定的排名区间的成员)

4、zremrangebyscore key min max (移除有序集合中给定的分数区间的成员)

Redis学习笔记(七)——数据结构之有序集合(sorted set)的更多相关文章
- Redis学习笔记(六)有序集合进阶
1.基础操作 ZCARD(获取成员数量) ZINCRBY key_name num member(将member的分数加num) ZCOUNT key_name min max(获取分数在min与ma ...
- Redis自学笔记:3.6入门-有序集合类型
3.6有序集合类型 3.6.1介绍 在集合类型基础上,为集合中每个元素都关联了一个分数,故可以获得 分数最高(最低)的前N个元素,可以获得指定范围内的元素等 有序集合中每个元素不同,但它们的分数却可以 ...
- Redis学习笔记七:独立功能之排序
sort 命令可以对列表键.集合键或有序集合键的值进行排序.sort 命令并不修改数据库值,只是输出有序. 127.0.0.1:6379> rpush numbers 9 8 7 6 1 2 3 ...
- Redis学习笔记七:主从集群
单机,单节点,单实例的Redis会有什么问题呢? 容易导致单点故障,那么如何解决呢? 可以通过主备方式 同时可以实现读写分离 这里的每个节点是全量的,镜像的. 单节点的容量有限而且单点的压力比较大,如 ...
- Redis学习笔记八:集群模式
作者:Grey 原文地址:Redis学习笔记八:集群模式 前面提到的Redis学习笔记七:主从复制和哨兵只能解决Redis的单点压力大和单点故障问题,接下来要讲的Redis Cluster模式,主要是 ...
- Redis学习笔记一:数据结构与对象
1. String(SDS) Redis使用自定义的一种字符串结构SDS来作为字符串的表示. 127.0.0.1:6379> set name liushijie OK 在如上操作中,name( ...
- python 操作redis之——有序集合(sorted set) (七)
#coding:utf8 import redis r =redis.Redis(host=") 1.Zadd 命令用于将一个或多个成员元素及其分数值加入到有序集当中.如果某个成员已经是有序 ...
- Redis学习笔记之Redis基本数据结构
Redis基础数据结构 Redis有5种基本数据结构:String(字符串).list(列表).set(集合).hash(哈希).zset(有序集合) 字符串string 字符串类型是Redis的va ...
- Redis学习笔记(二) Redis 数据类型
Redis 支持五种数据类型:string(字符串).list(列表).hash(哈希).set(集合)和 zset(有序集合),接下来我们讲解分别讲解一下这五种类型的的使用. String(字符串) ...
- Redis学习笔记~目录
回到占占推荐博客索引 百度百科 redis是一个key-value存储系统.和Memcached类似,它支持存储的value类型相对更多,包括string(字符串).list(链表).set(集合). ...
随机推荐
- JVM学习(六)JVM常见知识问答
文章更新时间:2020/04/21 1.什么是Java虚拟机?为什么Java被称作是"平台无关的编程语言"? Java虚拟机是一个可以执行Java字节码的虚拟机进程. Java源文 ...
- Linux环境下C++调试的三板斧
调试解决程序的漏洞,是程序员最基本的技能之一.用惯了图形化IDE,在目前使用gtest框架进行单元测试,需要通过xshell远程连接Linux虚拟机进行C++代码的调试时,觉得很不适应.经过几天查资料 ...
- 小程序开发-iView app的NoticeBar 通告栏修改背景颜色
NoticeBar 通告栏 这是个比较好用的组件,具体使用方法见 http://inmap.talkingdata.com/wx/index_prod.html#/components/notice- ...
- 使用 IIS 新建WebService站点供Android访问远程sqlserver数据库
新增网站 打开IIS控制台,找到服务根目录,右键,新建网站 网站设定 浏览测试 使用刚才生成的默认HelloWorld的服务1页面,记得加上端口号 http://localhost:8090/serv ...
- 关于Xilinx PCIE DMA的问答
关于Xilinx PCIE DMA的问答 很久没上博客园了,但由于之前在博客园写了几篇关于PCIE DMA的文章,很多同学给我发消息询问相关知识点,之前有空的时候都是语音一小时跟人细讲,最近由于工作繁 ...
- mapreduce的一些简单使用
一.键值对RDD的创建 1.从文件中加载 /opt目录下创建wordky.txt文件. wordky.txt文件中输入以下三行字符: Hadoop is good Spark is fast Spar ...
- Mac 效率工具必备神器 —— Alfred
前言 alfred 这款软件称为「神器」真是当之无愧.今天专门总结一下,作为之前 Mac 配置教程-开发篇 的补充. 需要说明的是,如果你发现我介绍的功能无法使用,则代表需要花钱购买它的 Powerp ...
- C++中头文件简介(stdio.h & chrono)
参考: 1. https://baike.baidu.com/item/stdio.h 2. https://www.cnblogs.com/jwk000/p/3560086.html 1. stdi ...
- javaOOP9.17刷题
今天在吃晚饭和朋友们聊天的时候,一个已经在自己写java全栈项目并且准备面试的同学说要我好好学习OOP这部分,他现在写代码写面试题,发现自己都忘了基类派生类调用构造函数时候的顺序是什么样的巴拉巴拉,说 ...
- 深入浅出具有划时代意义的G1垃圾回收器
G1诞生的背景 Garbage First(简称G1)收集器是垃圾收集器技术发展历史上的里程碑式的成果,它开创了收集器面向局部收集的设计思路和基于Region的内存布局形式.HotSpot开发团队最初 ...