1.概念
Redis 有序集合和集合一样也是 string 类型元素的集合,且不允许重复的成员。不同的是每个元素都会关联一个 double 类型的分数。redis 正是通过分数来为集合中的成员进行从小到大的排序。有序集合的成员是唯一的,但分数(score)却可以重复。集合是通过哈希表实现的,所以添加,删除,查找的复杂度都是 O(1)。 集合中最大的成员数为 232?- 1 (4294967295, 每个集合可存储40多亿个成员)应用:销量排行、积分排行、成绩排行,集合的value作为学号,成绩作为分数,插入集合的时候就已经排好顺序了。
2.赋值
向有序集合中添加一个或多个成员,或者更新已经存在的成员的分数
相关命令:127.0.0.1:6379> zadd user:4 1 白沙 4 万宝路
代码演示:
redisUtils.zadd(key, value, System.currentTimeMillis(), RedisConstants.datebase2); public Long zadd(String key, String value, double score, int index) { Jedis jedis = null; Long res = null; try { jedis = jedisPool.getResource(); jedis.select(index); res = jedis.zadd(key, score, value); } catch (Exception e) { log.error(e.getMessage()); } finally { close(jedis); } return res; }效果:
3.取值
(1)获取有序集合的成员数量
相关命令:127.0.0.1:6379>
zcard user:5
"2"
代码演示:
Long size = redisUtils.zcard(key, RedisConstants.datebase2); public Long zcard(String key, int index) { Jedis jedis = null; Long res = null; try { jedis = jedisPool.getResource(); jedis.select(index); res = jedis.zcard(key); } catch (Exception e) { log.error(e.getMessage()); } finally { close(jedis); } return res; }(2)计算有序集合中指定区间分数的成员数(返回value的个数)
相关命令:127.0.0.1:6379> zcount user:5 1 77
(integer) 1
代码演示:
Long sizes = redisUtils.zcount(key,0,-1); public Long zcount(String key, double min, double max) { Jedis jedis = null; try { jedis = jedisPool.getResource(); return jedis.zcount(key, min, max); } catch (Exception e) { log.error(e.getMessage()); return 0L; } finally { returnResource(jedisPool, jedis); } }(3)返回有序集合指定成员的索引
相关命令:
127.0.0.1:6379> zrange user:5 0 -1 (正序,0,-1返回所有)
1) "黄鹤楼"
2) "金陵十二钗"
127.0.0.1:6379> zrank user:5 金陵十二钗 (获取索引)
(integer) 1
(4)通过索引区间返回有序集合指定区间内的成员
相关命令:
127.0.0.1:6379>
zrange user:5 0 -1 (正序,0,-1返回所有)
1) "黄鹤楼"
2) "金陵十二钗"
127.0.0.1:6379> zrevrange user:5 0 -1(倒序,0,-1返回所有)
1) "金陵十二钗"
2) "黄鹤楼"
(5)通过分数返回有序集合指定区间的成员
相关命令:
127.0.0.1:6379> zrangebyscore user:5 0 77
1) "黄鹤楼"
127.0.0.1:6379> zrangebyscore user:5 77 88
1) "黄鹤楼"
2) "金陵十二钗"
(6)返回索引
127.0.0.1:6379>zrank user:5 金陵十二钗
(integer) 1
4.删除
(1)移除集合
127.0.0.1:6379> del user:4
(integer) 1
127.0.0.1:6379> zrange z1 0 -1
(empty list or set)
(2)移除集合中的一个或多个成员
127.0.0.1:6379> zrange user:5 0 -1
1) "黄鹤楼"
2) "金陵十二钗"
127.0.0.1:6379> zrem user:5 黄鹤楼
(integer) 1
127.0.0.1:6379> zrange user:5 0 -1
1) "金陵十二钗"
(3)移除有序集合中给定的排名区间的所有成员
127.0.0.1:6379> zadd user:4 1 白沙 4 万宝路
(integer) 2
127.0.0.1:6379> zremrangebyrank user:4 0 1
(integer) 2
127.0.0.1:6379> zrange user:4 0 -1
空
代码:
redisUtils.zremrangeByRank(key, 0, -1, RedisConstants.datebase2);(4)根据分数区间删除
zadd user:4 1 白沙 4 万宝路 18 南京
127.0.0.1:6379> zrange user:4 0 -1
1) "白沙"
2) "万宝路"
3) "南京"
127.0.0.1:6379> zremrangebyscore user:4 1 5
(integer) 2
127.0.0.1:6379> zrange user:4 0 -1
1) "南京"
5、增加分数
(1)增加元素的分组,返回值是更改后的分数:
127.0.0.1:6379> zrange user:4 0 -1
1) "白沙"
2) "万宝路"
3) "南京"
127.0.0.1:6379> zincrby user:4 100 白沙
127.0.0.1:6379> zrange user:4 0 -1
1) "万宝路"
2) "南京"
3) "白沙"
小结:
zadd(key, score, member):向名称为key的zset中添加元素member,score用于排序。如果该元素已经存在,则根据score更新该元素的顺序。zrem(key, member) :删除名称为key的zset中的元素memberzincrby(key, increment, member) :如果在名称为key的zset中已经存在元素member,则该元素的score增加increment;否则向集合中添加该元素,其score的值为incrementzrank(key, member) :返回名称为key的zset(元素已按score从小到大排序)中member元素的rank(即index,从0开始),若没有member元素,返回“nil”zrevrank(key, member) :返回名称为key的zset(元素已按score从大到小排序)中member元素的rank(即index,从0开始),若没有member元素,返回“nil”zrange(key, start, end):返回名称为key的zset(元素已按score从小到大排序)中的index从start到end的所有元素zrevrange(key, start, end):返回名称为key的zset(元素已按score从大到小排序)中的index从start到end的所有元素zrangebyscore(key, min, max):返回名称为key的zset中score >= min且score <= max的所有元素 zcard(key):返回名称为key的zset的基数,有几条数据zscore(key, element):返回名称为key的zset中元素element的score
zremrangebyrank(key, min, max):删除名称为key的zset中rank >= min且rank <= max的所有元素 zremrangebyscore(key, min, max) :删除名称为key的zset中score >= min且score <= max的所有元素
1.本站遵循行业规范,任何转载的稿件都会明确标注作者和来源;2.本站的原创文章,会注明原创字样,如未注明都非原创,如有侵权请联系删除!;3.作者投稿可能会经我们编辑修改或补充;4.本站不提供任何储存功能只提供收集或者投稿人的网盘链接。 |
标签: #redis #zset #删除元素 #有序集合和集合一样也是 #string #类型元素的集合 #且不允许重复的成员