首页 > 数据库 > Redis > Redis有序集合zset知识点有哪些

Redis有序集合zset知识点有哪些

WBOY
发布: 2023-05-27 17:23:00
转载
1156 人浏览过

Redis有序集合zset知识点有哪些

redis有序集合zset与普通集合set非常相似,是一个没有重复元素的字符串集合。
不同之处是有序集合的每个成员都关联了一个评分(score),这个评分(score)被用来按照从最低分
到最高分的方式排序集合中的成员。
集合的成员是唯一的,但是评分是可以重复的。
因为元素是有序的,所以你可以很快的根据评分(score)或者次序(position)来获取一个范围的元
素。
访问有序集合中的中间元素也是非常快的,因为你能够使用有序集合作为一个没有重复成员你的智能列
表。
zadd:添加元素
Redis有序集合zset知识点有哪些
zrange:score升序,获取指定索引范围的元素
返回存储在有序集合 key 中的指定范围的元素。 返回的元素可以认为是按score从最低到最
高排列,如果得分相同,将按字典排序。
下标参数 start 和 stop 都以 0 为底,也就是说,以 0 表示有序集第一个成员,以 1 表
示有序集第二个成员,以此类推。
你也可以使用负数下标,以 -1 表示最后一个成员, -2 表示倒数第二个成员,以此类推。
zrange key 0 -1:可以获取所有元素
withscores:让成员和它的 score 值一并返回,返回列表以 value1,score1, …, valueN,scoreN 的格式表示
可用版本:

= 1.2.0
时间复杂度:
O(log(N)+M), N 为有序集的基数,而 M 为结果集的基数。
返回值:
指定区间内,带有 score 值(可选)的有序集成员的列表
Redis有序集合zset知识点有哪些
zrevrange:score降序,获取指定索引范围的元素
返回存储在有序集合 key 中的指定范围的元素。 返回的元素可以认为是按score最高到最低
排列, 如果得分相同,将按字典排序。
下标参数 start 和 stop 都以 0 为底,也就是说,以 0 表示有序集第一个成员,以 1 表
示有序集第二个成员,以此类推。
你也可以使用负数下标,以 -1 表示最后一个成员, -2 表示倒数第二个成员,以此类推。
withscores:让成员和它的 score 值一并返回,返回列表以 value1,score1, …, valueN,scoreN 的格式表示
Redis有序集合zset知识点有哪些

zrangebyscore:按照score升序,返回指定score范围内的数据
Redis有序集合zset知识点有哪些
zincrby:为指定元素的score加上指定的增量
Redis有序集合zset知识点有哪些zrem:删除集合中多个元素
Redis有序集合zset知识点有哪些
zremrangebyrank:根据索引范围删除元素
Redis有序集合zset知识点有哪些
zremrangebyscore:根据score的范围删除元素
Redis有序集合zset知识点有哪些
zcount:统计指定score范围内元素的个数
Redis有序集合zset知识点有哪些
zrank:按照score升序,返回某个元素在集合中的排名

Redis有序集合zset知识点有哪些
zrevrank:按照score降序,返回某个元素在集合中的排名
Redis有序集合zset知识点有哪些
zscore:返回集合中指定元素的score

Redis有序集合zset知识点有哪些
数据结构
SortedSet(zset)是redis提供的一个非常特别的数据结构,内部使用到了2种数据结构。
1、hash表
类似于java中的Map,key为集合中的元素,value为元素对应的score,可以用来快速定
位元素定义的score,时间复杂度为O(1)
2、跳表
跳表(skiplist)是一个非常优秀的数据结构,实现简单,插入、删除、查找的复杂度均为O(logN)。
类似java中的ConcurrentSkipListSet,根据score的值排序后生成的一个跳表,可以快速按照位置的顺
序或者score的顺序查询元素。

以上是Redis有序集合zset知识点有哪些的详细内容。更多信息请关注PHP中文网其他相关文章!

相关标签:
来源:yisu.com
本站声明
本文内容由网友自发贡献,版权归原作者所有,本站不承担相应法律责任。如您发现有涉嫌抄袭侵权的内容,请联系admin@php.cn
热门教程
更多>
最新下载
更多>
网站特效
网站源码
网站素材
前端模板