Redis底层学习(六)—存储类型-ZSet篇

结构特点

适⽤场景:存储不重复且有序需求的数据,⽐如:学⽣的⾼考成绩。
它的内部采⽤“ 跳跃列表 ”实现,根据score进⾏排序

具体服务器操作命令

添加元素到zset中: ZADD [key] [score1] [member1] … [scoreN][memberN]
查看zset中某个元素的score值: ZSCORE [key] [member]

升序输出: ZRANGE [key] 0 -1 输出从下标0到下标-1(即倒数第⼀个)中的所有元素从⼩到

升序输出: ZRANGEBYSCORE [key] -inf +inf 与上⾯输出效果⼀样,输出score>=负⽆
穷,score<=正⽆穷的所有元素
降序输出: ZREVRANGE [key] 0 -1
根据某些score条件,升序展示zset中的元素: ZRANGEBYSCORE [key] [minScore] [maxS
core]
根据某些score条件,降序展示zset中的元素: ZREVRANGEBYSCORE [key] [maxScore] [m
inScore]
查看zset中的元素个数: ZCARD [key]
删除zset中的某个元素: ZREM key [member1] … [memberN]

底层结构

有序集合编码的内部实现可以是 ziplist 或 skiplist

zipList 压缩链表:
每个集合元素使⽤两个紧挨在⼀起的压缩列表节点来保存,第⼀个节点保存元素的成员( member ),⽽第⼆个节点则保存元素的分值( score )。压缩列表内的集合元素按分值( score )从⼩到⼤进⾏排序。
在这里插入图片描述

skiplist:
skiplist 编码的有序集合采⽤ zset 结构作为底层实现,⼀个zset同时包含⼀个字
典 dict 和⼀个跳跃表 zskiplist 。
在这里插入图片描述

在这里插入图片描述

当有序集合对象可以同时满⾜以下两个条件时,使⽤ ziplist 编码,否则使
⽤ skiplist 编码:
有序集合保存的元素数量⼩于等于128个
有序集合保存的所有元素成员的⻓度都⼩于64字节

应用场景

对点赞用户进行排序操作

  • 0
    点赞
  • 0
    收藏
    觉得还不错? 一键收藏
  • 0
    评论
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值