热门标签 | HotTags
当前位置:  开发笔记 > 编程语言 > 正文

Nosql之Redis:zset(有序集)数据类型及操作命令

一:概述zset全称为sorted-sets类型,和set数据类型有极为相似,都是字符串的集合,都不允许重复的成员出现在一个set中.两者的主要区别是zs

一:概述 zset全称为sorted-sets类型,和set数据类型有极为相似,都是字符串的集合,都不允许重复的成员 出现在一个set中.两者的主要区别是zset的每一个成员都会有一个分数(score)与之关联.redis正是通过分数来为集合中的成员进行从小到大的排序.zset的成员是唯


一:概述

zset全称为sorted-sets类型,和set数据类型有极为相似,都是字符串的集合,都不允许重复的成员

出现在一个set中.两者的主要区别是zset的每一个成员都会有一个分数(score)与之关联.redis正是通过分数来为集合中的成员进行从小到大的排序.zset的成员是唯一的,但分数(score)却可以重复.

在zset中添加、删除或更新一个成员都是非常快速的操作,其时间复杂度为集合中成员数量的对数.

Sorted-Sets中的成员在集合中的位置是有序的.

二:相关命令

1: zadd

命令格式: zadd key score member [[score] [member] …]

描述:将一个或多个 member 元素及其 score 值加入到有序集 key 当中.如果某个 member 已经是有序集的成员,那么更新这个 member 的 score 值,并通过重新插入这个 member 元素,来保证该 member 在正确的位置上。score 值可以是整数值或双精度浮点数。如果 key 不存在,则创建一个空的有序集并执行 ZADD 操作。当 key 存在但不是有序集类型时,返回一个错误。

时间复杂度: O(M*log(N)), N 是有序集的基数, M 为成功添加的新成员的数量

返回值:被成功添加的新成员的数量,不包括那些被更新的、已经存在的成员。

操作命令如下:

#添加一个元素

redis 127.0.0.1:6379> zadd zset_list 11 test1

(integer) 1

#添加多个元素

redis 127.0.0.1:6379> zadd zset_list 9 test2 10 test3

(integer) 2

#查看元素

redis 127.0.0.1:6379> zrange zset_list 0 -1 withscores

1) “test2″

2) “9″

3) “test3″

4) “10″

5) “test1″

6) “11″

redis 127.0.0.1:6379> zrange zset_list 0 -1

1) “test2″

2) “test3″

3) “test1″

# 添加已存在元素,且 score 值不变 操作不成功返回0

redis 127.0.0.1:6379> zadd zset_list 10 test1

(integer) 0

redis 127.0.0.1:6379> zrange zset_list 0 -1 withscores

1) “test2″

2) “9″

3) “test1″

4) “10″

5) “test3″

6) “10″

# 添加已存在元素,但是改变 score 值

redis 127.0.0.1:6379> zadd zset_list 7 test1

(integer) 0

redis 127.0.0.1:6379> zrange zset_list 0 -1 withscores

1) “test1″

2) “7″

3) “test2″

4) “9″

5) “test3″

6) “10″

2:zrem

命令格式: ZREM key member [member ...]

描述:移除有序集 key 中的一个或多个成员,不存在的成员将被忽略。

当 key 存在但不是有序集类型时,返回一个错误。

时间复杂度:O(M*log(N)), N 为有序集的基数, M 为被成功移除的成员的数量。

返回值:被成功移除的成员的数量,不包括被忽略的成员。

操作命令如下:

redis 127.0.0.1:6379> zrange zset_list 0 -1 withscores

1) “test1″

2) “7″

3) “test2″

4) “9″

5) “test3″

6) “10″

#移除单个元素

redis 127.0.0.1:6379> zrem zset_list test1

(integer) 1

redis 127.0.0.1:6379> zrange zset_list 0 -1 withscores

1) “test2″

2) “9″

3) “test3″

4) “10″

#移除多个

redis 127.0.0.1:6379> zrem zset_list test2 test3

(integer) 2

redis 127.0.0.1:6379> zrange zset_list 0 -1 withscores

(empty list or set)

# 移除不存在元素

redis 127.0.0.1:6379> zrem zset_list non-exists-element

(integer) 0

3:zcard

描述:返回zset集合的成员数

时间复杂度:O(1)

返回值:当 key 存在且是有序集(zset)类型时,返回集合内的成员数。不存在返回0。

操作命令如下:

redis 127.0.0.1:6379> zcard zset_list

(integer) 0

redis 127.0.0.1:6379> zadd zset_list 1 test1

(integer) 1

redis 127.0.0.1:6379> zcard zset_list

(integer) 1

4:zcount

命令格式:ZCOUNT key min max

描述:返回有序集 key 中, score 值在 min 和 max 之间(默认包括 score 值等于 min 或 max )的成员的数量。

时间复杂度: O(log(N)+M), N 为有序集的基数, M 为值在 min 和 max 之间的元素的数量。

返回值:score 值在 min 和 max 之间的成员的数量。

操作命令如下:

redis 127.0.0.1:6379> zrange zset_list 0 -1 withscores

1) “test1″

2) “1″

3) “test2″

4) “100″

5) “test3″

6) “200″

7) “test4″

Nosql之Redis:zset(有序集)数据类型及操作命令 - 文章图片 “300″

redis 127.0.0.1:6379> zcount zset_list 100 200

(integer) 2

redis 127.0.0.1:6379> zcount zset_list 100 300

(integer) 3

5: zscore

命令格式:ZSCORE key member

描述:返回有序集 key 中,成员 member 的 score 值。

如果 member 元素不是有序集 key 的成员,或 key 不存在,返回 nil 。

时间复杂度:O(1)

操作命令如下:

redis 127.0.0.1:6379> zrange zset_list 0 -1 withscores

1) “test1″

2) “1″

3) “test2″

4) “100″

5) “test3″

6) “200″

7) “test4″

Nosql之Redis:zset(有序集)数据类型及操作命令 - 文章图片 “300″

redis 127.0.0.1:6379> zscore zset_list test2

“100″

6:zincrby

命令格式:ZINCRBY key increment member

描述:为有序集 key 的成员 member 的 score 值加上增量 increment 。

时间复杂度:O(log(N))

返回值: 返回member 成员的新 score 值,以字符串形式表示。

操作命令如下:

redis 127.0.0.1:6379> zscore zset_list test2

“100″

redis 127.0.0.1:6379>

redis 127.0.0.1:6379> zincrby zset_list 10 test2

“110″

redis 127.0.0.1:6379> zincrby zset_list -6 test2

“104″

7:zrange

命令格式: ZRANGE key start stop [WITHSCORES]

描述:返回指定区间的成员。其中成员位置按 score 值递增(从小到大)来排序。 WITHSCORES选项是用来让成员和它的score值一并返回.(在前面我们已经用到过)

时间复杂度:O(log(N)+M), N 为有序集的基数,而 M 为结果集的基数。

返回值:返回指定区间的成员列表.

操作命令如下:

redis 127.0.0.1:6379> zrange zset_list 0 -1

1) “test1″

2) “test2″

3) “test3″

4) “test4″

redis 127.0.0.1:6379> zrange zset_list 0 -1 withscores

1) “test1″

2) “1″

3) “test2″

4) “104″

5) “test3″

6) “200″

7) “test4″

Nosql之Redis:zset(有序集)数据类型及操作命令 - 文章图片 “300″

#当给定区间不存在于有序集时的情况

redis 127.0.0.1:6379> zrange zset_list 10000 30000 withscores

(empty list or set)

7:zrevrange

命令格式:ZREVRANGE key start stop [WITHSCORES]

描述:和zrange一样使用,唯一不同是其成员位置按 score 值递减(从大到小)来排列。

8:zrangebyscore

命令格式:ZRANGEBYSCORE key min max [WITHSCORES] [LIMIT offset count]

描述:返回有序集key中所有score值介于min与max之间(包括等于)的成员.成员按score值递增(从小到大)排列 。min 和 max 可以是 -inf 和 +inf

可选limit参数指定返回结果的数量及区间。

时间复杂度:O(log(N)+M), N 为有序集的基数, M 为被结果集的基数。

返回值:指定区间内,带有 score 值(可选)的有序集成员的列表。

操作命令如下:

redis 127.0.0.1:6379> zrangebyscore zset_list -inf +inf

1) “test1″

2) “test2″

3) “test3″

4) “test4″

redis 127.0.0.1:6379> zrangebyscore zset_list -inf +inf withscores

1) “test1″

2) “1″

3) “test2″

4) “104″

5) “test3″

6) “200″

7) “test4″

Nosql之Redis:zset(有序集)数据类型及操作命令 - 文章图片 “300″

redis 127.0.0.1:6379> zrangebyscore zset_list -inf 100 withscores

1) “test1″

2) “1″

#显示大于100 小于等于700的成员

redis 127.0.0.1:6379> zrangebyscore zset_list (100 700

1) “test2″

2) “test3″

3) “test4″

#显示条件 100
redis 127.0.0.1:6379> zrangebyscore zset_list (100 (700

1) “test2″

2) “test3″

3) “test4″

8:zrevrangebyscore

命令格式: zrevrangebyscore key max min [WITHSCORES] [LIMIT offset count]

描述:和zrangebyscoreg一样,唯一不同的是成员按 score 值递减(从大到小)的次序排列。

9:zrank

命令格式: zrank key member

描述:返回有序集key中成员member的排名。成员按 score 值递增(从小到大)顺序排列。

排名以0开始,也就是说score 值最小的为0.

时间复杂度:O(log(N))

返回值:返回成员排名,member不存在返回nil.

9:zrevrank

命令格式: zrevrank key member

描述:返回有序集key中成员member的排名。成员按 score 值递增(从大到小)顺序排列。

排名以0开始,也就是说score 值最大的为0.

时间复杂度:O(log(N))

返回值:返回成员排名,member不存在返回nil.

10:zremrangebyrank

命令格式: ZREMRANGEBYRANK key start stop

描述:移除有序集 key 中,指定排名(rank)区间内的所有成员。区间分别以下标参数 start 和 stop 指出,包含 start 和 stop 在内。

下标参数 start 和 stop 都以 0 为底,也就是说,以 0 表示有序集第一个成员,以 1 表示有序集第二个成员,以此类推。

你也可以使用负数下标,以 -1 表示最后一个成员, -2 表示倒数第二个成员,以此类推。

时间复杂度:O(log(N)+M), N 为有序集的基数,而 M 为被移除成员的数量。

返回值:被移除成员的数量。

11:zremrangebyscore

命令格式:zremrangebyscore key min max

描述:移除score值介于min和max之间(等于)的成员

时间复杂度:O(log(N)+M), N 为有序集的基数,而 M 为被移除成员的数量。

返回值:被移除成员的数量。

操作如下:

# 移除所有score在 150 到 350 内的数据

redis> zremrangebyscore zset_list 100 200

(integer) 1

12:zunionstore

命令格式:ZUNIONSTORE destination numkeys key [key ...] [WEIGHTS weight [weight ...]] [AGGREGATE SUM|MIN|MAX]

描述:计算给定的一个或多个有序集的并集,其中给定 key 的数量必须以 numkeys 参数指定,并将该并集(结果集)储存到 destination 。默认情况下,结果集中某个成员的 score 值是所有给定集下该成员 score 值之 和 。

12: zinterstore

命令格式:ZINTERSTORE destination numkeys key [key ...] [WEIGHTS weight [weight ...]] [AGGREGATE SUM|MIN|MAX]

描述:计算给定的一个或多个有序集的交集。其中给定 key 的数量必须以 numkeys 参数指定,并将该交集(结果集)储存到 destination 。默认情况下,结果集中某个成员的 score 值是所有给定集下该成员 score 值之 和 。

时间复杂度:

O(N*K)+O(M*log(M)), N 为给定 key 中基数最小的有序集, K 为给定有序集的数量, M 为结果集的基数。

返回值:保存到 destination 的结果集成员数。

操作命令如下:

redis 127.0.0.1:6379> zrange z_ulist_1 0 -1 withscores

1) “jack”

2) “20″

3) “abc”

4) “30″

5) “bb”

6) “50″

7) “cc”

Nosql之Redis:zset(有序集)数据类型及操作命令 - 文章图片 “50″

redis 127.0.0.1:6379> zadd z_ulist_2 20 bb 40 789 48 a980

(integer) 3

redis 127.0.0.1:6379> zinterstore z_ulist_x 2 z_ulist_1 z_ulist_2

(integer) 1

redis 127.0.0.1:6379> zrange z_ulist_x 0 -1 withscores

1) “bb”

2) “70″





推荐阅读
  • 本文由编程笔记#小编为大家整理,主要介绍了logistic回归(线性和非线性)相关的知识,包括线性logistic回归的代码和数据集的分布情况。希望对你有一定的参考价值。 ... [详细]
  • 图解redis的持久化存储机制RDB和AOF的原理和优缺点
    本文通过图解的方式介绍了redis的持久化存储机制RDB和AOF的原理和优缺点。RDB是将redis内存中的数据保存为快照文件,恢复速度较快但不支持拉链式快照。AOF是将操作日志保存到磁盘,实时存储数据但恢复速度较慢。文章详细分析了两种机制的优缺点,帮助读者更好地理解redis的持久化存储策略。 ... [详细]
  • Oracle分析函数first_value()和last_value()的用法及原理
    本文介绍了Oracle分析函数first_value()和last_value()的用法和原理,以及在查询销售记录日期和部门中的应用。通过示例和解释,详细说明了first_value()和last_value()的功能和不同之处。同时,对于last_value()的结果出现不一样的情况进行了解释,并提供了理解last_value()默认统计范围的方法。该文对于使用Oracle分析函数的开发人员和数据库管理员具有参考价值。 ... [详细]
  • 本文讨论了如何使用IF函数从基于有限输入列表的有限输出列表中获取输出,并提出了是否有更快/更有效的执行代码的方法。作者希望了解是否有办法缩短代码,并从自我开发的角度来看是否有更好的方法。提供的代码可以按原样工作,但作者想知道是否有更好的方法来执行这样的任务。 ... [详细]
  • 本文介绍了Python爬虫技术基础篇面向对象高级编程(中)中的多重继承概念。通过继承,子类可以扩展父类的功能。文章以动物类层次的设计为例,讨论了按照不同分类方式设计类层次的复杂性和多重继承的优势。最后给出了哺乳动物和鸟类的设计示例,以及能跑、能飞、宠物类和非宠物类的增加对类数量的影响。 ... [详细]
  • 本文介绍了贝叶斯垃圾邮件分类的机器学习代码,代码来源于https://www.cnblogs.com/huangyc/p/10327209.html,并对代码进行了简介。朴素贝叶斯分类器训练函数包括求p(Ci)和基于词汇表的p(w|Ci)。 ... [详细]
  • 电话号码的字母组合解题思路和代码示例
    本文介绍了力扣题目《电话号码的字母组合》的解题思路和代码示例。通过使用哈希表和递归求解的方法,可以将给定的电话号码转换为对应的字母组合。详细的解题思路和代码示例可以帮助读者更好地理解和实现该题目。 ... [详细]
  • 也就是|小窗_卷积的特征提取与参数计算
    篇首语:本文由编程笔记#小编为大家整理,主要介绍了卷积的特征提取与参数计算相关的知识,希望对你有一定的参考价值。Dense和Conv2D根本区别在于,Den ... [详细]
  • 006_Redis的List数据类型
    1.List类型是一个链表结构的集合,主要功能有push,pop,获取元素等。List类型是一个双端链表的结构,我们可以通过相关操作进行集合的头部或者尾部添加删除元素,List的设 ... [详细]
  • 基于dlib的人脸68特征点提取(眨眼张嘴检测)python版本
    文章目录引言开发环境和库流程设计张嘴和闭眼的检测引言(1)利用Dlib官方训练好的模型“shape_predictor_68_face_landmarks.dat”进行68个点标定 ... [详细]
  • 本文介绍了在iOS开发中使用UITextField实现字符限制的方法,包括利用代理方法和使用BNTextField-Limit库的实现策略。通过这些方法,开发者可以方便地限制UITextField的字符个数和输入规则。 ... [详细]
  • EPPlus绘制刻度线的方法及示例代码
    本文介绍了使用EPPlus绘制刻度线的方法,并提供了示例代码。通过ExcelPackage类和List对象,可以实现在Excel中绘制刻度线的功能。具体的方法和示例代码在文章中进行了详细的介绍和演示。 ... [详细]
  • 超级简单加解密工具的方案和功能
    本文介绍了一个超级简单的加解密工具的方案和功能。该工具可以读取文件头,并根据特定长度进行加密,加密后将加密部分写入源文件。同时,该工具也支持解密操作。加密和解密过程是可逆的。本文还提到了一些相关的功能和使用方法,并给出了Python代码示例。 ... [详细]
  • 本文整理了315道Python基础题目及答案,帮助读者检验学习成果。文章介绍了学习Python的途径、Python与其他编程语言的对比、解释型和编译型编程语言的简述、Python解释器的种类和特点、位和字节的关系、以及至少5个PEP8规范。对于想要检验自己学习成果的读者,这些题目将是一个不错的选择。请注意,答案在视频中,本文不提供答案。 ... [详细]
  • 本文介绍了lua语言中闭包的特性及其在模式匹配、日期处理、编译和模块化等方面的应用。lua中的闭包是严格遵循词法定界的第一类值,函数可以作为变量自由传递,也可以作为参数传递给其他函数。这些特性使得lua语言具有极大的灵活性,为程序开发带来了便利。 ... [详细]
author-avatar
---残月_235_999
这个家伙很懒,什么也没留下!
PHP1.CN | 中国最专业的PHP中文社区 | DevBox开发工具箱 | json解析格式化 |PHP资讯 | PHP教程 | 数据库技术 | 服务器技术 | 前端开发技术 | PHP框架 | 开发工具 | 在线工具
Copyright © 1998 - 2020 PHP1.CN. All Rights Reserved | 京公网安备 11010802041100号 | 京ICP备19059560号-4 | PHP1.CN 第一PHP社区 版权所有