redis基本数据结构-有序集合zset

特性

  • 使用哈希表+跳表数据结构存储
  • 每个元素由 分数和字段名 两部分组成

  • 增加元素
zadd  key  score1  member1    [score2  member2   score3  member3 ...]
zadd scores 90 zhangsan   99  lisi  95  wangwu

返回3 (返回写入有序集合中的元素个数)

scores = {90 zhangsan,  99  lisi,  95  wangwu}

  • 修改元素的分数(与增加类似)
zadd  key score  member
zadd  socres   92 zhangsan

scores = {92 zhangsan, 99 lisi,  95 wangwu}

  • 获取元素的分数
zscore   key  member
zscore   scores lisi

返回99

  • 获取排名在某个范围内的元素列表(从小到大的升序)
zrange  key   startRank   endRank   [WITHSCORES]
zrange  scores  0   1   withscores

返回{92  zhangsan,   95  wangwu}

  • 获取排名在某个范围内的元素列表(从大到小降序)
zrevrange  key  startRank  endRank  [WITHSCORES]
zrevrange  scores  0  1  withscores

返回{99  lisi,    95  wangwu}

zrevrange   scores  0   -1  withscores

返回{99  lisi,  95 wangwu, 92 zhangsan}

说明:以上排序中,当score相同时,按照 '0' < '9' < 'A' < 'Z' < 'a' < 'z' 的顺序排序。

  • 获取指定分数范围内的元素
ZRangeByScore   key  min   max  [WITHSCORES]   [LIMIT   offset  count]
zrangebyscore   scores 93  100  withscores   

返回 {99  lisi,  95 wangwu}

zrangebyscore   scores (95  +inf  withscores

返回 {99  lisi}

zrangebyscore  scores 90 100 LIMIT 1  10000

返回 {99  lisi,   95 wangwu}, 跳过了1个(92 zhangsan),返回10000个,但是不足10000个所以只返回了实际个数的元素

  • 增加某个元素的分数
ZIncrBy   key   increment    member
zincrby   scores   5   zhangsan

返回 97 (张三的92 + 5 == 97)

scores =  {97 zhangsan, 99 lisi,  95 wangwu}

  • 获取集合中的元素数量
ZCard   key
zcard  scores

返回3

  • 获取指定分数范围内的元素个数
ZCount   key   min  max
zcount  scores  (95   +inf

返回2 ( (95, +inf)共有2个)

  • 删除一个或多个元素
ZRem   key  member1  [member2   member3 ...]
zrem scores  zhangsan   wagnwu

返回2 (实际删除的元素个数)

scores = {99   lisi}

zrem scores 

返回1,删除scores的所有元素(删除前还剩一个)

  • 按照排名范围删除元素
ZRemRangeByRank   key   startRank   endRank
zadd scores 97  zhangsan   99  lisi   95  wangwu    90  liuwu

scores = { 97 zhangsan, 99 lisi, 95 wangwu, 90 liuwu}

zremrangebyrank   scores   0   2

返回3 (删除了3个)

scores = { 99 lisi}

  • 按照分数范围删除元素
ZRemRangeByScore  key  minScore  maxScore
zadd scores 97  zhangsan  95  wangwu    90  liuwu

scores = { 97 zhangsan, 99 lisi, 95 wangwu, 90 liuwu}

zremrangebyscore  scores   90   96

返回2(实际删除了2个元素)

scores = { 97 zhangsan, 99 lisi}

  • 获得元素的排名(升序)
ZRank   key  member
zrank  scores  lisi

返回1,排名1

zrank  scors  zhangsan

返回0,排名0

  • 获得元素的排名(降序)
ZRevRank   key  member
zrevrank   scores  lisi

返回0,排名0

zrevrank  scores  zhangsan

返回1,排名1

  • 有序集合的交集运算
ZInterStore    destSet   setCounts  zset1  zset2 [zset3 ...]    [WEIGHTS   weight1  weight2 [weight3 ...]]   [AGGREGATE  SUM | MAX | MIN]

参数说明:

destSet: 交集运算结果存放到destSet 有序集合

setCounts:参与运算的集合数量

zset1  zset2 ... :参与运算的集合,setCounts 要与实际参与运算的集合数量一致

WEIGHTS:命令选型,后面接每个set的在进行 SUM 或 MAX  或 MIN 之前先使用weight值对自身的score进行乘法运算,然后再进行SUM | MAX | MIN 运算

AGGRATE:命令选型,后接SUM 集合中相同元素的分数经过weight*score后相加  或  MAX 集合中相同元素的分数经过weight * score后取分数大的那个 或  MIN 集合中相同元素的分数经过weight * score 后取分数小的;

zadd zset1  100 first  200 second

zset1 = {100  first,  200 second}

zadd zset2 10 first  20 second

zset2 = {10 first,  20 second}

zinterstore zset3 2 zset1 zset2  ===  zinterstore  zset3   zset1   zset2   AGGREGATE SUM ===  zinterstore  zset3  WEIGHTS  1  1  AGGREGATE  SUM

zset3 = {110  first,   220  second}

zinterstore  zset3   2   zset1  zset2  WEIGHTS  0.01   1   AGGREGATE  MAX

zset3 = {max(100 * 0.01, 10 * 1) first,    max(200 * 0.01,  20 * 1)  second} ===  {1  first,   2 second}

  • 有序集合的并集运算

与 交集运算 类似,略

ZInterStore    destSet   setCounts  zset1  zset2 [zset3 ...]    [WEIGHTS   weight1  weight2 [weight3 ...]]   [AGGREGATE  SUM | MAX | MIN]

redis基本数据结构-有序集合的更多相关文章

  1. 第二百九十九节,python操作redis缓存-SortSet有序集合类型,可以理解为有序列表

    python操作redis缓存-SortSet有序集合类型,可以理解为有序列表 有序集合,在集合的基础上,为每元素排序:元素的排序需要根据另外一个值来进行比较,所以,对于有序集合,每一个元素有两个值, ...

  2. redis 系列14 有序集合对象

    一. 有序集合概述 Redis 有序集合对象和集合对象一样也是string类型元素的集合,且不允许重复的成员.不同的是每个元素都会关联一个double类型的分数.redis正是通过分数来为集合中的成员 ...

  3. Redis学习---Redis操作之有序集合

    有序集合,在集合的基础上,为每元素排序:元素的排序需要根据另外一个值来进行比较,所以,对于有序集合,每一个元素有两个值,即:值和分数,分数专门用来做排序. zadd(name, *args, **kw ...

  4. redis:php-redis中有序集合 zset的使用

    ZSET(stored set) 和 set 一样是字符串的集合,不同的是每个元素都会关联一个 double 类型的 score .实现使用的是 skip list 和 hash table , sk ...

  5. redis列表和有序集合

    redis中的list数据类型是可以插入重复数据的,有去重的需求的话可以用redis有序集合数据类型 Redis Zadd 命令用于将一个或多个成员元素及其分数值加入到有序集当中. 如果某个成员已经是 ...

  6. redis 入门之有序集合

    zadd 将一个或多个 member 元素及其 score 值加入到有序集 key 当中.如果某个 member 已经是有序集的成员,那么更新这个 member 的 score 值,并通过重新插入这个 ...

  7. redis:order set有序集合类型的操作(有序集合)

    1. order set有序集合类型的操作(有序集合) 有序集合是在无序集合的基础上加了一个排序的依据,这个排序依据叫score,因此声明一个集合为有序集合的时候要加上score(作为排序的依据) 1 ...

  8. (PHP)redis Zset(有序集合 sorted set)操作

    /** * * Zset操作 * sorted set操作 * 有序集合 * sorted set 它在set的基础上增加了一个顺序属性,这一属性在修改添加元素的时候可以指定,每次指定后,zset会自 ...

  9. redis: Zset有序集合类型(七)

    存值:zadd myset 1 one 取值:zrange myset 0 -1 127.0.0.1:6379> zadd myset 1 one #存值 分值为1 (integer) 1 12 ...

  10. 9、Redis五大数据类型---有序集合Zset(sorted set)

    一.简介 zset与set异同 相同之处: 都是没有重复元素的字符串集合 不同之处: 有序集合zset的每个成员都关联了一个评分(score),这个评分(score)被用来按照从最低分到最高分的方式排 ...

随机推荐

  1. C#TMS系统学习(BaseCity页面)

    C#TMS系统代码-基础页面BaseCity学习 本人纯新手,刚进公司跟领导报道,我说我是java全栈,他问我会不会C#,我说大学学过,他说这个TMS系统就给你来管了.外包已经把代码给我了,这几天先把 ...

  2. 5GC 系统架构

    目录 文章目录 目录 前文列表 4G/5G 核心网对比 4G/5G 核心网融合架构 5GC 架构 AMF 功能 SMF 功能 NSSF 功能 UPF 功能 AF.PCF & NEF 功能 BS ...

  3. 安全高效 | AIRIOT智慧工地管理解决方案

      建筑工地施工材料.机械设备.工程车.人员各个环节管理相对复杂.建筑业也是安全事故频发的高危行业,安全管控尤为重要.建筑施工单位想要保障安全生产,做好能源消耗管控降低生产成本,需要解决掉很多现状问题 ...

  4. go 从入门到了解

    一,GO的安装与配置 官网:https://golang.org/dl/ 镜像:https://golang.google.cn/dl/ 1,GOPATH GOPATH在windows上的默认值:%U ...

  5. 鸿蒙HarmonyOS实战-Web组件(基本使用和属性)

    前言 Web是一种基于互联网的技术和资源的网络服务系统.它是指由许多互连的计算机组成的全球性计算机网络,使用户能够通过浏览器访问和交互式使用各种信息和资源,如网页.文档.图片.视频.音频等.通过Web ...

  6. Vue3使用Composition API实现响应式

    title: Vue3使用Composition API实现响应式 date: 2024/5/29 下午8:10:24 updated: 2024/5/29 下午8:10:24 categories: ...

  7. Aspire项目发布到远程k8s集群

    前提 你必须会创建aspire项目,不会的请先看微服务新体验之Aspire初体验 Aspirate (Aspir8) Aspirate 是将aspire项目发布到k8s集群的工具 安装aspirate ...

  8. 8.9考试总结(NOIP模拟34)[Merchant·Equation·Rectangle]

    一个人有表里两面,你能看到的,仅仅是其中一面而已. 今日已成往昔,明日即将到来,为此理所当然之事,感到无比痛心. T1 Merchant 解题思路 我和正解也许就是差了一个函数(我格局小了..) nt ...

  9. H5图片预览

    官方链接下载示例项目需要注册账号,似乎有点不友好,不想注册账号的可以去gitee上下载示例项目 如果你上来就是把previewImg.js 放在head中可能会出现意想不到的错误,比如下面这样子,遇到 ...

  10. Linux间进程通信--消息队列

    本系列文章主要是学习记录Linux下进程间通信的方式. 常用的进程间通信方式:管道.FIFO.消息队列.信号量以及共享存储. 参考文档:<UNIX环境高级编程(第三版)> 参考视频:Lin ...