Redis数据类型之ZSet类型

    技术2025-07-11  7

    定义

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

    常用语法命令

    赋值: 向有序集合添加一个或多个成员,或者更新已存在成员的分数

    ZADD key score1 member1 [score2 member2]

    取值: 1、获取有序集合的成员数

    ZCARD key

    2、计算在有序集合中指定区间分数的成员数

    ZCOUNT key min max

    3、返回有序集合中指定成员的索引

    ZRANK key member

    4、通过索引区间返回有序集合成指定区间内的成员(低到高)

    ZRANGE key start stop [WITHSCORES]

    5、通过分数返回有序集合指定区间内的成员

    ZRANGEBYSCORE key min max [WITHSCORES] [LIMIT]

    6、返回有序集中指定区间内的成员,通过索引,分数从高到底

    ZREVRANGE key start stop [WITHSCORES]

    7、返回有序集合中指定分数区间内的成员,分数从高到低排序

    ZREVRANGEBYSCORE key max min [WITHSCORES]

    删除: 1、移除集合

    del key

    2、移除有序集合中的一个或多个成员

    ZREM key member [member ...]

    3、移除有序集合中给定的排名区间的所有成员(第一名是0)(低到高排序)

    ZREMRANGEBYRANK key start stop

    4、移除有序集合中给定的分数区间的所有成员

    ZREMRANGEBYSCORE key min max

    5、增加member元素的分数increment,返回值是更改后的分数

    ZINCBY key increment member

    应用场景

    常用于排行榜,销量排名、积分排名等 1、比如twitter 的public timeline可以以发表时间作为score来存储,这样获取时就是自动按时间排好序的。 2、 比如一个存储全班同学成绩的Sorted Set,其集合value可以是同学的学号,而score就可以是其考试得分,这样在数据插入集合的时候,就已经进行了天然的排序。 3、 还可以用Sorted Set来做带权重的队列,比如普通消息的score为1,重要消息的score为2,然后工作线程可以选择按score的倒序来获取工作任务。让重要的任务优先执行。

    Processed: 0.012, SQL: 9