Redis数据类型之ZSet有序集合类型

举报
兮动人 发表于 2021/08/19 10:28:03 2021/08/19
2.8k+ 0 0
【摘要】 Redis数据类型之ZSet有序集合类型

1.3. 有序集合(sorted set) ZSET

1.3.1. 简介

  1. Redis 有序集合和集合一样也是string类型元素的集合,且不允许重复的成员。
  2. 不同的是每个元素都会关联一个double类型的分数。redis正是通过分数来为集合中的成员进行从小到大的排序。
  3. 有序集合的成员是唯一的,但分数(score)却可以重复。
  4. 集合是通过哈希表实现的,所以添加,删除,查找的复杂度都是O(1)。 集合中最大的成员数为 232 - 1 (4294967295, 每个集合可存储40多亿个成员)。

Redis的ZSet是有序、且不重复
(很多时候,我们都将redis中的有序集合叫做zsets,这是因为在redis中,有序集合相关的操作指令都是以z开头的)

1.3.2. 命令

赋值语法:

  • ZADD key score1 member1 [score2 member2]
    向有序集合添加一个或多个成员,或者更新已存在成员的分数
    在这里插入图片描述

取值语法:

  • ZCARD key 获取有序集合的成员数
    在这里插入图片描述
  • ZCOUNT key min max 计算在有序集合中指定区间分数的成员数
    在这里插入图片描述
  • ZRANK key member 返回有序集合中指定成员的索引
    在这里插入图片描述
  • ZRANGE key start stop [WITHSCORES]
    通过索引区间返回有序集合成指定区间内的成员(低到高)
    在这里插入图片描述
  • ZRANGEBYSCORE key min max [WITHSCORES ] [LIMIT] ,通过分数返回有序集合指定区间的成员
    在这里插入图片描述
  • ZREVRANGE key start stop [WITHSCORES]
    返回有序集中指定区间内的成员,通过索引,分数从高到底
    在这里插入图片描述
  • ZREVRANGEBYSCORE key max min [WITHSCORES] ,返回有序集合中指定分数区间的成员,分数从高到低排序
    在这里插入图片描述

删除语法:

  • del key 移除集合
  • ZREM key member [member …] 移除有序集合中的一个或多个成员
    在这里插入图片描述
  • ZREMRANGEBYRANK key start stop 移除有序集合中给定的排名区间的所有成员(第一名是0)(低到高排序)
    在这里插入图片描述
  • ZREMRANGEBYSCORE key min max 移除有序集合中给定的分数区间的所有成员
    在这里插入图片描述
  • ZINCRBY key increment member 增加member元素的分数increment,返回值是更改后的分数
    在这里插入图片描述

1.3.3. 应用场景

常应用于:排行榜

  1. 比如twitter 的public timeline可以以发表时间作为score来存储,这样获取时就是自动按时间排好序的。

  2. 比如一个存储全班同学成绩的Sorted Set,其集合value可以是同学的学号,而score就可以是其考试得分,这样在数据插入集合的时候,就已经进行了天然的排序。

  3. 还可以用Sorted Set来做带权重的队列,比如普通消息的score为1,重要消息的score为2,然后工作线程可以选择按score的倒序来获取工作任务。让重要的任务优先执行。
    在这里插入图片描述

【声明】本内容来自华为云开发者社区博主,不代表华为云及华为云开发者社区的观点和立场。转载时必须标注文章的来源(华为云社区)、文章链接、文章作者等基本信息,否则作者和本社区有权追究责任。如果您发现本社区中有涉嫌抄袭的内容,欢迎发送邮件进行举报,并提供相关证据,一经查实,本社区将立刻删除涉嫌侵权内容,举报邮箱: cloudbbs@huaweicloud.com
  • 点赞
  • 收藏
  • 关注作者

作者其他文章

评论(0

抱歉,系统识别当前为高风险访问,暂不支持该操作

    全部回复

    上滑加载中

    设置昵称

    在此一键设置昵称,即可参与社区互动!

    *长度不超过10个汉字或20个英文字符,设置后3个月内不可修改。

    *长度不超过10个汉字或20个英文字符,设置后3个月内不可修改。