redis 有序集合zset命令

备注:测试版本 redis 4.0.9

有序集合(sorted set)命令概述

Redis 有序集合和集合一样也是string类型元素的集合,且不允许重复的成员。

不同的是每个元素都会关联一个double类型的分数。redis正是通过分数来为集合中的成员进行从小到大的排序。

有序集合的成员是唯一的,但分数(score)却可以重复。

集合是通过哈希表实现的,所以添加,删除,查找的复杂度都是O(1)。 集合中最大的成员数为 232 - 1 (4294967295, 每个集合可存储40多亿个成员)。

命令概述
ZADD向有序集合添加一个或多个成员,或者更新已存在成员的分数
ZCARD获取有序集合的成员数
ZCOUNT计算在有序集合中指定区间分数的成员数
ZINCRBY有序集合中对指定成员的分数加上增量
ZINTERSTORE计算给定的一个或多个有序集的交集并将结果集存储在新的有序集合 key 中
ZLEXCOUNT在有序集合中计算指定字典区间内成员数量
ZRANGE通过索引区间返回有序集合成指定区间内的成员
ZRANGEBYLEX通过字典区间返回有序集合的成员
ZRANGEBYSCORE通过分数返回有序集合指定区间内的成员
ZRANK返回有序集合中指定成员的索引
ZREM移除有序集合中的一个或多个成员
ZREMRANGEBYLEX移除有序集合中给定的字典区间的所有成员
ZREMRANGEBYRANK移除有序集合中给定的排名区间的所有成员
ZREMRANGEBYSCORE移除有序集合中给定的分数区间的所有成员
ZREVRANGE返回有序集中指定区间内的成员,通过索引,分数从高到底
ZREVRANGEBYSCORE返回有序集中指定分数区间内的成员,分数从高到低排序
ZREVRANK返回有序集合中指定成员的排名,有序集成员按分数值递减(从大到小)排序
ZSCORE返回有序集中,成员的分数值
ZUNIONSTORE计算给定的一个或多个有序集的并集,并存储在新的 key 中
ZSCAN迭代有序集合中的元素(包括元素成员和元素分值)

1.1 ZADD命令

语法:

ZADD key score1 member1 [score2 member2] 向有序集合添加一个或多个成员,或者更新已存在成员的分数

测试记录

127.0.0.1:6379> zadd my_db 1 Oracle
(integer) 1
127.0.0.1:6379> zadd my_db 1 MySQL
(integer) 1
127.0.0.1:6379> zadd my_db 2 Redis
(integer) 1
127.0.0.1:6379> zadd my_db 2 Memcache
(integer) 1
127.0.0.1:6379> 
127.0.0.1:6379> zrange my_db 0 -1 withscores
1) "MySQL"
2) "1"
3) "Oracle"
4) "1"
5) "Memcache"
6) "2"
7) "Redis"
8) "2"
127.0.0.1:6379> 

1.2 ZCARD命令

语法:

ZCARD key 获取有序集合的成员数

测试记录

del key my_db
127.0.0.1:6379> zadd my_db 1 Oracle
(integer) 1
127.0.0.1:6379> zadd my_db 1 MySQL
(integer) 1
127.0.0.1:6379> zadd my_db 2 Redis
(integer) 1
127.0.0.1:6379> zadd my_db 2 Memcache
(integer) 1
127.0.0.1:6379> zcard my_db
(integer) 4
127.0.0.1:6379> 

1.3 ZCOUNT命令

语法:

ZCOUNT key min max 计算在有序集合中指定区间分数的成员数

测试记录

del key my_db
127.0.0.1:6379> zadd my_db 1 Oracle
(integer) 1
127.0.0.1:6379> zadd my_db 1 MySQL
(integer) 1
127.0.0.1:6379> zadd my_db 2 Redis
(integer) 1
127.0.0.1:6379> zadd my_db 2 Memcache
(integer) 1
127.0.0.1:6379> zcount my_db 1 3
(integer) 4
127.0.0.1:6379> zcount my_db 1 1
(integer) 2
127.0.0.1:6379> 

1.4 ZINCRBY命令

语法:

ZINCRBY key increment member 有序集合中对指定成员的分数加上增量 increment

测试记录

del key my_db
127.0.0.1:6379> zadd my_db 1 Oracle
(integer) 1
127.0.0.1:6379> zadd my_db 1 MySQL
(integer) 1
127.0.0.1:6379> zadd my_db 2 Redis
(integer) 1
127.0.0.1:6379> zadd my_db 2 Memcache
(integer) 1
127.0.0.1:6379> zincrby my_db 1 Oracle
"2"
127.0.0.1:6379> zrange my_db 0 -1 withscores
1) "MySQL"
2) "1"
3) "Memcache"
4) "2"
5) "Oracle"
6) "2"
7) "Redis"
8) "2"
127.0.0.1:6379> 

1.5 ZINTERSTORE命令

语法:

ZINTERSTORE destination numkeys key [key ...] 计算给定的一个或多个有序集的交集并将结果集存储在新的有序集合 key 中

测试记录

127.0.0.1:6379> del key my_db
(integer) 1
127.0.0.1:6379> del key my_db2
(integer) 0
127.0.0.1:6379> zadd my_db 1 Oracle
(integer) 1
127.0.0.1:6379> zadd my_db 1 MySQL
(integer) 1
127.0.0.1:6379> zadd my_db 2 Redis
(integer) 1
127.0.0.1:6379> zadd my_db 2 MongoDB
(integer) 1
127.0.0.1:6379> zadd my_db2 100 Oracle
(integer) 1
127.0.0.1:6379> zadd my_db2 100 Redis
(integer) 1
127.0.0.1:6379> zinterstore sum_db 2 my_db my_db2
(integer) 2
127.0.0.1:6379> zrange sum_db 0 -1 withscores
1) "Oracle"
2) "101"
3) "Redis"
4) "102"
127.0.0.1:6379> 

1.6 ZLEXCOUNT命令

语法:

ZLEXCOUNT key min max 在有序集合中计算指定字典区间内成员数量

测试记录

127.0.0.1:6379> del key my_db
(integer) 1
127.0.0.1:6379> zadd my_db 1 Oracle
(integer) 1
127.0.0.1:6379> zadd my_db 1 MySQL
(integer) 1
127.0.0.1:6379> zadd my_db 2 Redis
(integer) 1
127.0.0.1:6379> zadd my_db 2 MongoDB
(integer) 1
127.0.0.1:6379> zlexcount my_db - +
(integer) 4
127.0.0.1:6379> zlexcount my_db [A [F
(integer) 0
127.0.0.1:6379> 

1.7 ZRANGE命令

语法:

ZRANGE key start stop [WITHSCORES] 通过索引区间返回有序集合成指定区间内的成员

测试记录

127.0.0.1:6379> del key my_db
(integer) 1
127.0.0.1:6379> del key my_db2
(integer) 0
127.0.0.1:6379> zadd my_db 1 Oracle
(integer) 1
127.0.0.1:6379> zadd my_db 1 MySQL
(integer) 1
127.0.0.1:6379> zadd my_db 2 Redis
(integer) 1
127.0.0.1:6379> zadd my_db 2 MongoDB
127.0.0.1:6379> zrange my_db 0 -1 withscores
1) "MySQL"
2) "1"
3) "Oracle"
4) "1"
5) "MongoDB"
6) "2"
7) "Redis"
8) "2"
127.0.0.1:6379> 

1.8 ZRANGEBYLEX命令

语法:

ZRANGEBYLEX key min max [LIMIT offset count] 通过字典区间返回有序集合的成员

测试记录

127.0.0.1:6379> del key my_db
(integer) 1
127.0.0.1:6379> del key my_db2
(integer) 0
127.0.0.1:6379> zadd my_db 1 Oracle
(integer) 1
127.0.0.1:6379> zadd my_db 1 MySQL
(integer) 1
127.0.0.1:6379> zadd my_db 2 Redis
(integer) 1
127.0.0.1:6379> zadd my_db 2 MongoDB
(integer) 1
127.0.0.1:6379> zrangebylex my_db - +
1) "MySQL"
2) "Oracle"
3) "MongoDB"
4) "Redis"
127.0.0.1:6379> zrangebylex my_db - (O
1) "MySQL"
127.0.0.1:6379> zrangebylex my_db - (M
(empty list or set)
127.0.0.1:6379> 

1.9 ZRANGEBYSCORE命令

语法:

ZRANGEBYSCORE key min max [WITHSCORES] [LIMIT] 通过分数返回有序集合指定区间内的成员

测试记录

127.0.0.1:6379> del key my_db
(integer) 1
127.0.0.1:6379> del key my_db2
(integer) 0
127.0.0.1:6379> zadd my_db 1 Oracle
(integer) 1
127.0.0.1:6379> zadd my_db 1 MySQL
(integer) 1
127.0.0.1:6379> zadd my_db 2 Redis
(integer) 1
127.0.0.1:6379> zadd my_db 2 MongoDB
(integer) 1
127.0.0.1:6379> zrangebyscore my_db 0 1
1) "MySQL"
2) "Oracle"
127.0.0.1:6379> 
127.0.0.1:6379> 
127.0.0.1:6379> zrangebyscore my_db 0 1 withscores
1) "MySQL"
2) "1"
3) "Oracle"
4) "1"
127.0.0.1:6379> zrangebyscore my_db 0 2 withscores
1) "MySQL"
2) "1"
3) "Oracle"
4) "1"
5) "MongoDB"
6) "2"
7) "Redis"
8) "2"
127.0.0.1:6379> 

1.10 ZRANK命令

语法:

ZRANK key member 返回有序集合中指定成员的索引

测试记录

127.0.0.1:6379> del key my_db
(integer) 1
127.0.0.1:6379> del key my_db2
(integer) 0
127.0.0.1:6379> zadd my_db 1 Oracle
(integer) 1
127.0.0.1:6379> zadd my_db 1 MySQL
(integer) 1
127.0.0.1:6379> zadd my_db 2 Redis
(integer) 1
127.0.0.1:6379> zadd my_db 2 MongoDB
(integer) 1
127.0.0.1:6379> zrank my_db MySQL
(integer) 0
127.0.0.1:6379> zrank my_db Oracle
(integer) 1
127.0.0.1:6379> 

1.11 ZREM命令

语法:

ZREM key member [member ...] 移除有序集合中的一个或多个成员

测试记录

127.0.0.1:6379> del key my_db
(integer) 1
127.0.0.1:6379> del key my_db2
(integer) 0
127.0.0.1:6379> zadd my_db 1 Oracle
(integer) 1
127.0.0.1:6379> zadd my_db 1 MySQL
(integer) 1
127.0.0.1:6379> zadd my_db 2 Redis
(integer) 1
127.0.0.1:6379> zadd my_db 2 MongoDB
(integer) 1
127.0.0.1:6379> del key my_db
(integer) 1
127.0.0.1:6379> del key my_db2
(integer) 0
127.0.0.1:6379> zadd my_db 1 Oracle
(integer) 1
127.0.0.1:6379> zadd my_db 1 MySQL
(integer) 1
127.0.0.1:6379> zadd my_db 2 Redis
(integer) 1
127.0.0.1:6379> zadd my_db 2 MongoDB
(integer) 1

1.12 ZREMRANGEBYLEX命令

语法:

ZREMRANGEBYLEX key min max 移除有序集合中给定的字典区间的所有成员

测试记录

127.0.0.1:6379> del key my_db
(integer) 1
127.0.0.1:6379> del key my_db2
(integer) 0
127.0.0.1:6379> zadd my_db 1 Oracle
(integer) 1
127.0.0.1:6379> zadd my_db 1 MySQL
(integer) 1
127.0.0.1:6379> zadd my_db 2 Redis
(integer) 1
127.0.0.1:6379> zadd my_db 2 MongoDB
(integer) 1
127.0.0.1:6379> zrange my_db 0 -1 withscores
1) "MySQL"
2) "1"
3) "Oracle"
4) "1"
5) "MongoDB"
6) "2"
7) "Redis"
8) "2"
127.0.0.1:6379> zremrangebylex my_db [A [Z
(integer) 4
127.0.0.1:6379> zrange my_db 0 -1 withscores
(empty list or set)
127.0.0.1:6379> 

1.13 ZREMRANGEBYRANK命令

语法:

ZREMRANGEBYRANK key start stop 移除有序集合中给定的排名区间的所有成员

测试记录

127.0.0.1:6379> del key my_db
(integer) 0
127.0.0.1:6379> 
127.0.0.1:6379> zadd my_db 1 Oracle 1 MySQL 2 Redis 2 MOngoDB
(integer) 4
127.0.0.1:6379> 
127.0.0.1:6379> zrange my_db 0 -1 withscores
1) "MySQL"
2) "1"
3) "Oracle"
4) "1"
5) "MOngoDB"
6) "2"
7) "Redis"
8) "2"
127.0.0.1:6379> zremrangebyrank my_db 0 1
(integer) 2
127.0.0.1:6379> zrange my_db 0 -1 withscores
1) "MOngoDB"
2) "2"
3) "Redis"
4) "2"
127.0.0.1:6379> 

1.14 ZREMRANGEBYSCORE命令

语法:

ZREMRANGEBYSCORE key min max 移除有序集合中给定的分数区间的所有成员

测试记录

127.0.0.1:6379> del key my_db
(integer) 1
127.0.0.1:6379> zadd my_db 1 Oracle 1 MySQL 2 Redis 2 MOngoDB
(integer) 4
127.0.0.1:6379> 
127.0.0.1:6379> 
127.0.0.1:6379> 
127.0.0.1:6379> 
127.0.0.1:6379> zrange my_db 0 -1 withscores
1) "MySQL"
2) "1"
3) "Oracle"
4) "1"
5) "MOngoDB"
6) "2"
7) "Redis"
8) "2"
127.0.0.1:6379> zremrangebyscore my_db 0 1
(integer) 2
127.0.0.1:6379> zrange my_db 0 -1 withscores
1) "MOngoDB"
2) "2"
3) "Redis"
4) "2"
127.0.0.1:6379> 

1.15 ZREVRANGE命令

语法:

ZREVRANGE key start stop [WITHSCORES] 返回有序集中指定区间内的成员,通过索引,分数从高到底

1.16 ZREVRANGEBYSCORE命令

语法:

ZREVRANGEBYSCORE key max min [WITHSCORES] 返回有序集中指定分数区间内的成员,分数从高到低排序

测试记录

127.0.0.1:6379> del key my_db
(integer) 1
127.0.0.1:6379> zadd my_db 1 Oracle 1 MySQL 2 Redis 2 MOngoDB
(integer) 4
127.0.0.1:6379> zrevrange my_db 0 -1 withscores
1) "Redis"
2) "2"
3) "MOngoDB"
4) "2"
5) "Oracle"
6) "1"
7) "MySQL"
8) "1"
127.0.0.1:6379> 

1.17 ZREVRANK命令

语法:

ZREVRANK key member 返回有序集合中指定成员的排名,有序集成员按分数值递减(从大到小)排序

测试记录

127.0.0.1:6379> del key my_db
(integer) 1
127.0.0.1:6379> zadd my_db 1 Oracle 1 MySQL 2 Redis 2 MOngoDB
(integer) 4
127.0.0.1:6379> ZREVRANK my_db Oracle
(integer) 2
127.0.0.1:6379> ZREVRANK my_db MySQL
(integer) 3
127.0.0.1:6379> ZREVRANK my_db Redis
(integer) 0
127.0.0.1:6379> ZREVRANK my_db Mongodb
(nil)
127.0.0.1:6379> 

1.18 ZSCORE命令

语法:

ZSCORE key member 返回有序集中,成员的分数值

测试记录

127.0.0.1:6379> del key my_db
(integer) 1
127.0.0.1:6379> zadd my_db 1 Oracle 1 MySQL 2 Redis 2 MOngoDB
(integer) 4
127.0.0.1:6379> zrevrange my_db 0 -1 withscores
1) "Redis"
2) "2"
3) "MOngoDB"
4) "2"
5) "Oracle"
6) "1"
7) "MySQL"
8) "1"
127.0.0.1:6379> zscore my_db Oracle
"1"
127.0.0.1:6379> 

1.19 ZUNIONSTORE命令

语法:

ZUNIONSTORE destination numkeys key [key ...] 计算给定的一个或多个有序集的并集,并存储在新的 key 中

测试记录

127.0.0.1:6379> zadd programmer 2000 peter 3500 jack 5000 tom
(integer) 3
127.0.0.1:6379> zadd manager 2000 henry 3500 mary 4000 bob
(integer) 3
127.0.0.1:6379>  ZRANGE programmer 0 -1 WITHSCORES
1) "peter"
2) "2000"
3) "jack"
4) "3500"
5) "tom"
6) "5000"
127.0.0.1:6379> ZRANGE manager 0 -1 WITHSCORES
1) "henry"
2) "2000"
3) "mary"
4) "3500"
5) "bob"
6) "4000"
127.0.0.1:6379> 
# 公司决定加薪。。。除了程序员。。。
127.0.0.1:6379> ZUNIONSTORE salary 2 programmer manager WEIGHTS 1 3   
(integer) 6
127.0.0.1:6379> ZRANGE salary 0 -1 WITHSCORES
 1) "peter"
 2) "2000"
 3) "jack"
 4) "3500"
 5) "tom"
 6) "5000"
 7) "henry"
 8) "6000"
 9) "mary"
10) "10500"
11) "bob"
12) "12000"
127.0.0.1:6379> 

1.20 ZSCAN命令

语法:

ZSCAN key cursor [MATCH pattern] [COUNT count] 迭代有序集合中的元素(包括元素成员和元素分值)

参考

1.https://www.redis.net.cn/tutorial/3505.html

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

“相关推荐”对你有帮助么?

  • 非常没帮助
  • 没帮助
  • 一般
  • 有帮助
  • 非常有帮助
提交
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值