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中的元素member
zincrby(key, increment, member) :如果在名称为key的zset中已经存在元素member,则该元素的score增加increment;否则向集合中添加该元素,其score的值为increment
zrank(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的所有元素