spring data redis 遇到的“坑”——set集合的 Srandmember

Posted 那些年的代码

tags:

篇首语:本文由小常识网(cha138.com)小编为大家整理,主要介绍了spring data redis 遇到的“坑”——set集合的 Srandmember相关的知识,希望对你有一定的参考价值。

sRandMember 命令是用于方法 set 集合中的“随机”元素
1
命令格式为

sRandMember key [count]
1
以下内容来自 http://www.redis.net.cn/order/3604.html

1.如果 count 为正数,且小于集合基数,那么命令返回一个包含 count 个元素的数组,数组中的元素各不相同。

2.如果 count 大于等于集合基数,那么返回整个集合。

3.如果 count 为负数,那么命令返回一个数组,数组中的元素可能会重复出现多次,而数组的长度为 count 的绝对值。
1
2
3
4
5
而 spring 封装的 redis 是每次使用的指令如下,即每次都是上述的第三种情况

sRandMember key [-count]
1
spring 的默认是允许重复元素的,源码如下:

List<V> org.springframework.data.redis.core.DefaultSetOperations.randomMembers(K key, long count)

public List<V> randomMembers(K key, final long count) {
    if (count < 0) {
        throw new IllegalArgumentException("Use a positive number for count. "
                + "This method is already allowing duplicate elements.");
    }
    final byte[] rawKey = rawKey(key);
    List<byte[]> rawValues = execute(new RedisCallback<List<byte[]>>() {
        public List<byte[]> doInRedis(RedisConnection connection) {
            return connection.sRandMember(rawKey, -count);
        }
    }, true);

    return deserializeValues(rawValues);
}

以上是关于spring data redis 遇到的“坑”——set集合的 Srandmember的主要内容,如果未能解决你的问题,请参考以下文章

用redis的scan命令代替keys命令,以及在spring-data-redis中遇到的问题

Redis连接池Lettuce踩坑记录

spring-data-redis 动态切换数据源

redis集群 与spring-data-redis 集成

Redis @Reference在Spring Data Redis中不起作用

Redis + Jedis + Spring整合遇到的异常(转)