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

关于redis:redis-八redis之Zset

redis系列文章:[链接]本篇起源:[链接]公众号:雨中散步撒哈拉备注:欢送关注公众号,一起学习,共同进步!一、基本概念Redis有序汇合和汇合一样也是string类型元素的汇合,且不容许反复的成员。不同的是每个元素都会关联一个double类型的分数。redis正是通过分数来为汇合中的成员进行从小到大的排序。有序汇合的成

redis系列文章:
https://liudongdong.top/categ…
本篇起源:
https://liudongdong.top/archi…
公众号:雨中散步撒哈拉
备注:欢送关注公众号,一起学习,共同进步!

一、基本概念

Redis 有序汇合和汇合一样也是 string 类型元素的汇合,且不容许反复的成员。

不同的是每个元素都会关联一个 double 类型的分数。redis 正是通过分数来为汇合中的成员进行从小到大的排序。

有序汇合的成员是惟一的,但分数(score)却能够反复。

汇合是通过哈希表实现的,所以增加,删除,查找的复杂度都是 O(1)。 汇合中最大的成员数为 232 – 1 (4294967295, 每个汇合可存储40多亿个成员)。

实例:

127.0.0.1:6379> zadd zset 1 one 2 two 3 three 4 four 5 five
(integer) 5
127.0.0.1:6379> zrange zset 0 -1
1) "one"
2) "two"
3) "three"
4) "four"
5) "five"
127.0.0.1:6379>
二、命令分类

依据集体了解和便于学习,进行了简略分类!
分为以下几类:

  1. 新增成员
  2. 删除成员
  3. 查问成员

1. 新增成员

  1. zadd:新增成员

2. 删除成员

  1. zrem:依据指定key进行删除
  2. zremrangebylex:依据指定汇合区间进行删除
  3. zremrangebyrank:依据指定排名区间进行删除
  4. zremrangebyscore:依据分数区间进行删除

3. 查问成员

  1. zcard:查问汇合成员数量
  2. zcount:分数区间成员数量
  3. zlexcount:成员区间成员数量
  4. zscore:指定key和值,获取分数
  5. zrange:获取成员信息
  6. zrank:指定key和值,获取下标
  7. zrangebylex:指定汇合区间,获取列表
  8. zrangebyscore:指定分数区间,获取列表
  9. zrevrange:倒序展现列表
  10. zrevrangebyscore:依据分数区间,倒序展现列表
  11. zreverank:倒序获取成员下标
三、命令实际

1. 新增成员

127.0.0.1:6379> keys *
(empty list or set)
127.0.0.1:6379> zadd zset 1 one 2 two 3 three 4 four 5 five
(integer) 5
127.0.0.1:6379> zrange zset 0 -1
1) "one"
2) "two"
3) "three"
4) "four"
5) "five"
127.0.0.1:6379>

2. 删除成员

# 移除zset下的one
127.0.0.1:6379> zrem zset one
(integer) 1
127.0.0.1:6379> zrange zset 0 -1
1) "two"
2) "three"
3) "four"
4) "five"
# 移除分数排名为1和2成员
127.0.0.1:6379> zremrangebyrank zset 1 2
(integer) 2
127.0.0.1:6379> zrange zset 0 -1
1) "two"
2) "five"
# 移除分数区间为[1,2]
127.0.0.1:6379> zrange zset 0 -1
1) "two"
2) "five"
127.0.0.1:6379> zremrangebyscore zset 1 2
(integer) 1
127.0.0.1:6379> zrange zset 0 -1
1) "five"
127.0.0.1:6379> 

3. 查问成员

127.0.0.1:6379> zrange zset 0 -1
1) "one"
2) "two"
3) "three"
4) "four"
5) "five"
# 查问汇合数量
127.0.0.1:6379> zcard zset
(integer) 5
# 查问问题在[0,5]区间内的成员
127.0.0.1:6379> zcount zset 0 5
(integer) 5
# 依据汇合区间进行统计
127.0.0.1:6379> zlexcount zset - +
(integer) 5
# 依据key和value值,获取分数
127.0.0.1:6379> zscore zset four
"4"
# 获取所有汇合信息
127.0.0.1:6379> zrange zset 0 -1
1) "one"
2) "two"
3) "three"
4) "four"
5) "five"
127.0.0.1:6379> zrange zset 0 3
1) "one"
2) "two"
3) "three"
4) "four"
# 依据key和值获取下标
127.0.0.1:6379> zrank zset three
(integer) 2
# 依据汇合区间进行获取汇合成员
127.0.0.1:6379> zrangebylex zset - +
1) "one"
2) "two"
3) "three"
4) "four"
5) "five"
# 依据分数区间进行获取汇合列表
127.0.0.1:6379> zrangebyscore zset 0 4
1) "one"
2) "two"
3) "three"
4) "four"
# 倒序排列汇合
127.0.0.1:6379> zrevrange zset 0 -1
1) "five"
2) "four"
3) "three"
4) "two"
5) "one"
# 倒序排列依据分数区间
127.0.0.1:6379> zrevrangebyscore zset 5 2
1) "five"
2) "four"
3) "three"
4) "two"
# 倒序排列,依据key和value,获取下标
127.0.0.1:6379> zrevrank zset three
(integer) 2
127.0.0.1:6379>
附录

下表列出了 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 …] 计算给定的一个或多个有序集的交加并将后果集存储在新的有序汇合 destination 中
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]](https://www.runoob.com/redis/…) 通过分数返回有序汇合指定区间内的成员
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]](https://www.runoob.com/redis/…) 迭代有序汇合中的元素(包含元素成员和元素分值)

推荐阅读
  • 浅析python实现布隆过滤器及Redis中的缓存穿透原理_python
    本文带你了解了位图的实现,布隆过滤器的原理及Python中的使用,以及布隆过滤器如何应对Redis中的缓存穿透,相信你对布隆过滤 ... [详细]
  • C#实现文件的压缩与解压
    2019独角兽企业重金招聘Python工程师标准一、准备工作1、下载ICSharpCode.SharpZipLib.dll文件2、项目中引用这个dll二、文件压缩与解压共用类 ... [详细]
  • 双指针法在链表问题中应用广泛,能够高效解决多种经典问题,如合并两个有序链表、合并多个有序链表、查找倒数第k个节点等。本文将详细介绍这些应用场景及其解决方案。 ... [详细]
  • 本文详细介绍了在 CentOS 7 系统中配置 fstab 文件以实现开机自动挂载 NFS 共享目录的方法,并解决了常见的配置失败问题。 ... [详细]
  • 利用python爬取豆瓣电影Top250的相关信息,包括电影详情链接,图片链接,影片中文名,影片外国名,评分,评价数,概况,导演,主演,年份,地区,类别这12项内容,然后将爬取的信息写入Exce ... [详细]
  • 本文介绍了在 Java 编程中遇到的一个常见错误:对象无法转换为 long 类型,并提供了详细的解决方案。 ... [详细]
  • Visual Studio Code (VSCode) 是一款功能强大的源代码编辑器,支持多种编程语言,具备丰富的扩展生态。本文将详细介绍如何在 macOS 上安装、配置并使用 VSCode。 ... [详细]
  • 本文详细介绍了 InfluxDB、collectd 和 Grafana 的安装与配置流程。首先,按照启动顺序依次安装并配置 InfluxDB、collectd 和 Grafana。InfluxDB 作为时序数据库,用于存储时间序列数据;collectd 负责数据的采集与传输;Grafana 则用于数据的可视化展示。文中提供了 collectd 的官方文档链接,便于用户参考和进一步了解其配置选项。通过本指南,读者可以轻松搭建一个高效的数据监控系统。 ... [详细]
  • 包含phppdoerrorcode的词条 ... [详细]
  • Spring Data JdbcTemplate 入门指南
    本文将介绍如何使用 Spring JdbcTemplate 进行数据库操作,包括查询和插入数据。我们将通过一个学生表的示例来演示具体步骤。 ... [详细]
  • 本文节选自《NLTK基础教程——用NLTK和Python库构建机器学习应用》一书的第1章第1.2节,作者Nitin Hardeniya。本文将带领读者快速了解Python的基础知识,为后续的机器学习应用打下坚实的基础。 ... [详细]
  • 本文介绍了如何在 ASP.NET 中设置 Excel 单元格格式为文本,获取多个单元格区域并作为表头,以及进行单元格合并、赋值、格式设置等操作。 ... [详细]
  • 本文介绍了如何在 Spring 3.0.5 中使用 JdbcTemplate 插入数据并获取 MySQL 表中的自增主键。 ... [详细]
  • 通过将常用的外部命令集成到VSCode中,可以提高开发效率。本文介绍如何在VSCode中配置和使用自定义的外部命令,从而简化命令执行过程。 ... [详细]
  • 如果应用程序经常播放密集、急促而又短暂的音效(如游戏音效)那么使用MediaPlayer显得有些不太适合了。因为MediaPlayer存在如下缺点:1)延时时间较长,且资源占用率高 ... [详细]
author-avatar
伊劾kj
这个家伙很懒,什么也没留下!
PHP1.CN | 中国最专业的PHP中文社区 | DevBox开发工具箱 | json解析格式化 |PHP资讯 | PHP教程 | 数据库技术 | 服务器技术 | 前端开发技术 | PHP框架 | 开发工具 | 在线工具
Copyright © 1998 - 2020 PHP1.CN. All Rights Reserved | 京公网安备 11010802041100号 | 京ICP备19059560号-4 | PHP1.CN 第一PHP社区 版权所有