• Redis 有序集合和集合一样也是 string 类型元素的集合,且不允许重复的成员。
  • 不同的是每个元素都会关联一个 double 类型的分数。redis 正是通过分数来为集合中的成员进行从小到大的排序。
  • 有序集合的成员是唯一的,但分数(score)却可以重复。
  • 集合是通过哈希表实现的,所以添加,删除,查找的复杂度都是 O(1)。 集合中最大的成员数为 232 - 1 (4294967295, 每个集合可存储40多亿个成员)

应用:销量排行、积分排行、成绩排行,集合的value作为学号,成绩作为分数,插入集合的时候就已经排好顺序了。

向有序集合中添加一个或多个成员,或者更新已经存在的成员的分数

相关命令: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;

(1)获取有序集合的成员数量

相关命令:127.0.0.1:6379>

zcard user:5

代码演示:

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

(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的所有元素

Redis 有序集合和集合一样也是 string 类型元素的集合,且不允许重复的成员。不同的是每个元素都会关联一个 double 类型的分数。redis 正是通过分数来为集合中的成员进行从小到大的排序。有序集合的成员是唯一的,但分数(score)却可以重复。集合是通过哈希表实现的,所以添加,删除,查找的复杂度都是 O(1)。 集合中最大的成员数为 232- 1 (4294967295, 每个集合可存储40多亿个成员)。...
如果使用redis zset结构,key不能直接设置过期时间,又想对member设置过期删除时,可以使用这个脚本根据score进行过期删除。大家可以参考下,score的格式需要自定义调整下。 删除脚本redis-del-keys.sh (main) #!/bin/bash ##redis主机IP host=$1 ##redis端口 port=$2 ##redis端口 password=$3 ##r...
我已经对该库进行了3年以上的维护,但是我没有足够的时间来提供可靠的支持和持续的开发。 任何现有的或新的问题将不予处理,我不保证合并任何新的请求请求。 如果有人愿意接管此项目,请随时分叉此项目,并给我发消息以在此自述文件中添加指向您的分叉的链接。 cpp_redis cpp_redis是C ++ 11异步多平台轻量级Redis客户端,支持同步操作,流水线,标记和高可用性。 cpp_redis没有依赖项。 它唯一的要求是C++11 。 它没有网络模块,因此您可以自由配置自己的模块,也可以使用默认模块( ) cpp_redis :: client cpp_redis::client client; client.connect(); client.set( " hello " , " 42 " ); client.get( " hello " , [](cpp_redis::reply& reply) { std::cout << reply << std::endl; // ! also sup
redis之Zset操作 集合Zset:在set基础上加了一个score。 Zset设置:ZADD zset01 60 v1 70 v2 80 v3 90 v4 100 v5 Zset获取等级:ZRANGE zset01 0 -1 Zset逆序获取等级:ZREVRANGE zset01 0 -1 Zset获取分数和等级:ZRANGE zset01 0 -1 withscores 127.0.0.1:6379[1]> ZADD zset01 60 v1 70 v2 80 v3 90 v4 1
1、zadd :添加元素,格式是:zadd zset的key score值 项的值, Score和项可以是多对,score可以是整数,也可以是浮点数,还可以是+inf表示无穷大,-inf表示负无穷大 操作如下: java示例代码: import redis.clients.jedis.Jedis; import java.util.HashMap; import java.util.Map; * redis中对于ZSet类型的: zadd 操作示例 * zadd :添加...
Redis的基本数据类型一、字符串类型及其操作二、hash类型及其操作三、list类型及操作set类型及操作应用范围:应用案例1:zset类型和操作应用范围:key命令的使用 一、字符串类型及其操作 字符串类型是Redis中最为基础的数据存储类型,它在Redis中是二进制安全的,这便意味着该类型可以接受任何格式的数据,如JPEG图像数据或Json对象描述信息等。在Redis中字符串类型的Value最多可以 容纳的数据长度是512M。 SET key value:将key设置成指定字符串,如果存在就覆盖原有值
Redis ZSet(Sorted Set)是一种带权重的有序集合。在 Redis 中,每个元素都有一个分数,用于排序。ZSet 的成员是唯一的,但分数(score)可以相同。 ZSet 的底层实现使用了跳跃表(skip list),这是一种用于快速排序的数据结构。因此,ZSet 可以在常数时间内执行插入、删除和查找操作。 你可以使用 ZSet 来实现排行榜、消息时间线等功能。它还可以用于范围查询,例如查找排名前 10 的用户。