redis | zset命令

本文详细介绍了 Redis 中 ZSet 数据类型的常用命令及其使用方法,包括如何添加元素、获取元素及其分数、计数、排序及删除等操作。

摘要生成于 C知道 ,由 DeepSeek-R1 满血版支持, 前往体验 >

zset

zset命令详解

  • 设置

# ZADD key score member [score member ...]  将所有指定成员添加到键为key有序集合,score是权重
127.0.0.1:6379> ZADD sortset 5 for 4 you 3 love 2 hello 10 al
(integer) 5

  • 获取

# ZRANGE key start stop [WITHSCORES]  返回指定范围内的元素
127.0.0.1:6379> ZRANGE sortset 0 -1
1) "hello"
2) "love"
3) "you"
4) "for"
5) "al"
127.0.0.1:6379> ZRANGE sortset 0 -1 withscores
 1) "hello"
 2) "2"
 3) "love"
 4) "3"
 5) "you"
 6) "4"
 7) "for"
 8) "5"
 9) "al"
10) "10"

# ZCARD key  返回元素个数
127.0.0.1:6379> ZCARD sortset
(integer) 5

# ZCOUNT key min max  指定score范围的元素个数。
127.0.0.1:6379> ZCOUNT sortset 1 5
(integer) 4

# ZSCORE key member  返回有序集key中,成员member的score值
127.0.0.1:6379> ZSCORE sortset love
"3"

  • 排序

# ZRANGEBYSCORE key min max [WITHSCORES] [LIMIT offset count] 返回有序集合中指定分数区间内的成员,分数由低到高排序。
127.0.0.1:6379> ZRANGEBYSCORE sortset -inf +inf
1) "hello"
2) "love"
3) "you"
4) "for"
5) "al"

# ZREVRANGEBYSCORE key max min [WITHSCORES] [LIMIT offset count] 返回有序集合中指定分数区间内的成员,分数由高到低排序。
127.0.0.1:6379> ZREVRANGEBYSCORE sortset +inf -inf
1) "al"
2) "for"
3) "you"
4) "love"
5) "hello"

  • 删除

# ZREM key member [member ...]  删除多个成员


### Redis ZSet 操作命令及用法 Redis 的有序集合(Sorted Set,简称 ZSet)是一种非常强大的数据结构,它结合了集合的唯一性和列表的有序性。每个元素都关联一个评分(score),并且元素按照评分值从小到大排序[^2]。 以下是 Redis 中与 ZSet 相关的操作命令及其用法: #### 1. 添加元素 `ZADD key score member [score member ...]` 该命令用于向 ZSet 中添加一个或多个成员,或者更新已存在成员的分数。如果成员已经存在,则更新其分数。返回值为成功添加的新成员数量。 ```python redis> ZADD myzset 1 "one" (integer) 1 redis> ZADD myzset 2 "two" (integer) 1 ``` #### 2. 获取指定范围内的成员 `ZRANGE key start stop [WITHSCORES]` 该命令用于获取 ZSet 中从 `start` 到 `stop` 范围内的成员,按分数从小到大排序。如果使用 `WITHSCORES` 参数,则同时返回成员的分数。 ```python redis> ZRANGE myzset 0 -1 WITHSCORES 1) "one" 2) "1" 3) "two" 4) "2" ``` #### 3. 获取指定范围内的成员(逆序) `ZREVRANGE key start stop [WITHSCORES]` 该命令与 `ZRANGE` 类似,但返回的成员是按分数从大到小排序。 ```python redis> ZREVRANGE myzset 0 -1 WITHSCORES 1) "two" 2) "2" 3) "one" 4) "1" ``` #### 4. 根据分数范围获取成员 `ZRANGEBYSCORE key min max [WITHSCORES] [LIMIT offset count]` 该命令用于获取分数在 `min` 和 `max` 之间的所有成员。默认情况下,`min` 和 `max` 是包含的,可以通过前缀 `(min` 或 `(max` 来排除边界值。 ```python redis> ZRANGEBYSCORE myzset 1 2 WITHSCORES 1) "one" 2) "1" 3) "two" 4) "2" ``` #### 5. 增加成员的分数 `ZINCRBY key increment member` 该命令用于将 ZSet 中某个成员的分数增加指定的值,并返回更新后的分数。 ```python redis> ZINCRBY myzset 2 "one" "3" ``` #### 6. 计算交集和并集 `ZINTERSTORE destination numkeys key [key ...] [WEIGHTS weight [weight ...]] [AGGREGATE SUM|MIN|MAX]` `ZUNIONSTORE destination numkeys key [key ...] [WEIGHTS weight [weight ...]] [AGGREGATE SUM|MIN|MAX]` 这两个命令分别用于计算多个 ZSet 的交集和并集,并将结果存储到新的 ZSet 中。可以通过 `WEIGHTS` 参数为每个 ZSet 设置权重,通过 `AGGREGATE` 参数指定聚合方法。 ```python redis> ZINTERSTORE both_scores 2 scores1 scores2 WEIGHTS 2 3 AGGREGATE MAX ``` #### 7. 删除成员 `ZREM key member [member ...]` 该命令用于从 ZSet 中删除一个或多个成员。如果成员不存在,则忽略。 ```python redis> ZREM myzset "one" (integer) 1 ``` #### 8. 获取成员的排名 `ZRANK key member` `ZREVRANK key member` 这两个命令分别用于获取成员在 ZSet 中的排名,前者按分数从小到大排序,后者按分数从大到小排序。如果成员不存在,则返回 `nil`。 ```python redis> ZRANK myzset "two" (integer) 1 ``` #### 9. 获取成员的分数 `ZSCORE key member` 该命令用于获取 ZSet 中某个成员的分数。如果成员不存在,则返回 `nil`。 ```python redis> ZSCORE myzset "two" "2" ``` ### 时间复杂度 - `ZADD`、`ZREM`:O(log(N)),其中 N 是 ZSet 中的成员数。 - `ZRANGE`、`ZREVRANGE`:O(log(N)+M),其中 M 是返回的成员数量。 - `ZRANGEBYSCORE`:O(log(N)+M),其中 M 是返回的成员数量[^4]。
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值