备注:测试版本 redis 4.0.9
Table of Contents
- 有序集合(sorted set)命令概述
- 1.1 ZADD命令
- 1.2 ZCARD命令
- 1.3 ZCOUNT命令
- 1.4 ZINCRBY命令
- 1.5 ZINTERSTORE命令
- 1.6 ZLEXCOUNT命令
- 1.7 ZRANGE命令
- 1.8 ZRANGEBYLEX命令
- 1.9 ZRANGEBYSCORE命令
- 1.10 ZRANK命令
- 1.11 ZREM命令
- 1.12 ZREMRANGEBYLEX命令
- 1.13 ZREMRANGEBYRANK命令
- 1.14 ZREMRANGEBYSCORE命令
- 1.15 ZREVRANGE命令
- 1.16 ZREVRANGEBYSCORE命令
- 1.17 ZREVRANK命令
- 1.18 ZSCORE命令
- 1.19 ZUNIONSTORE命令
- 1.20 ZSCAN命令
- 参考
有序集合(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] 迭代有序集合中的元素(包括元素成员和元素分值)
复制
参考
「喜欢这篇文章,您的关注和赞赏是给作者最好的鼓励」
关注作者
【版权声明】本文为墨天轮用户原创内容,转载时必须标注文章的来源(墨天轮),文章链接,文章作者等基本信息,否则作者和墨天轮有权追究责任。如果您发现墨天轮中有涉嫌抄袭或者侵权的内容,欢迎发送邮件至:contact@modb.pro进行举报,并提供相关证据,一经查实,墨天轮将立刻删除相关内容。
文章被以下合辑收录
评论
相关阅读
Redis 挂 AGPLv3 “战袍”,开源江湖风云突变
青年数据库学习互助会
64次阅读
2025-05-08 10:04:49
Redis概要
听溪
51次阅读
2025-04-11 10:23:10
Redis改协议内幕曝光!核心开发者亲述被“踢出局”,外部贡献者几乎全跑光了!
老鱼笔记
47次阅读
2025-04-17 10:41:56
Redis数据库——Cluster集群模式
编程Cookbook
46次阅读
2025-04-16 15:34:44
安装与配置Redis
鲁鲁
44次阅读
2025-04-11 10:26:10
使用Jedis访问Redis数据库
怀念和想念
40次阅读
2025-04-11 15:08:30
Redis geo 实战:“附近的人”实现,打造社交的新维度
老王两点中
40次阅读
2025-04-11 09:02:30
亚马逊:MemoryDB,一款内存优先的云数据库
数据库应用创新实验室
30次阅读
2025-04-18 09:54:15
Redis提供的持久化机制
luyingjun
29次阅读
2025-04-11 15:11:05
优雅遍历和删除特定开头的key
陌殇流苏
26次阅读
2025-04-25 12:17:03