结构特点
适⽤场景:存储不重复且有序需求的数据,⽐如:学⽣的⾼考成绩。
它的内部采⽤“ 跳跃列表 ”实现,根据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字节
应用场景
对点赞用户进行排序操作