«

redis中的opsForList().range()如何使用

时间:2024-8-2 10:48     作者:韩俊     分类: Mysql


这篇“redis中的opsForList().range()如何使用”文章的知识点大部分人都不太理解,所以小编给大家总结了以下内容,内容详细,步骤清晰,具有一定的借鉴价值,希望大家阅读完这篇文章能有所收获,下面我们一起来看看这篇“redis中的opsForList().range()如何使用”文章吧。

结论(具体测试数据请往下看)

1、start—end总体保持着顺序就没问题

2、按照顺序,即便start < -N或者end > N-1也能查询出数据

3、特殊用法:通过stringRedisTemplate.opsForList().range(key, 0, -1)可以查询索引第一个到索引倒数第一个(即所有数据)

1、环境 redis

2、测试代码:

  @Resource
    private StringRedisTemplate stringRedisTemplate;

    @Test
    void testRedis() {
        String key = "testList";
        String[] data = new String[]{"1_1", "1-2", "2_1", "2_2"};
        Boolean flag = stringRedisTemplate.hasKey(key);
        if (!flag) {
            stringRedisTemplate.opsForList().leftPushAll(key, data);
        }
        List<String> range = stringRedisTemplate.opsForList().range(key, -100, -1);
        System.out.println("range = " + range);
    }

3、测试数据(假设List长度为N)

4、测试从索引倒数开始

4.1、stringRedisTemplate.opsForList().range(key, -4, -1)

从结果看:从索引倒数第4个&mdash;&mdash;索引倒数第1个

4.2、stringRedisTemplate.opsForList().range(key, -3, -1)

从结果看:从索引倒数第3个&mdash;&mdash;索引倒数第1个

4.3、stringRedisTemplate.opsForList().range(key, -3, -2)

从结果看:从索引倒数第3个&mdash;&mdash;索引倒数第2个

4.4、stringRedisTemplate.opsForList().range(key, -2, -3)

从结果看:从索引倒数第2个&mdash;&mdash;索引倒数第3个不行,从索引倒数第3个&mdash;&mdash;索引倒数第2个可以。

结论:从索引倒数第N个开始,要按照顺序(即 -N、-(N-1)、-(N-2)、&hellip;&hellip;、-1),逆序是不行的

5、测试从索引正数开始

5.1、stringRedisTemplate.opsForList().range(key, 0, 3)

从结果看:从索引第1个&mdash;&mdash;索引第4个

5.2、stringRedisTemplate.opsForList().range(key, 1,2)

从结果看:从索引第2个&mdash;&mdash;索引第3个

5.3、stringRedisTemplate.opsForList().range(key, 2,1)

从结果看:从索引第3个&mdash;&mdash;索引第2个不行,从索引第2个&mdash;&mdash;索引第3个可以

结论:从索引0开始,要按照顺序(即 0、1、2、&hellip;&hellip;、N-1),逆序是不行的

6、测试索引倒数&mdash;&mdash;索引正数(正数索引,下标 0 为第一个)

6.1、stringRedisTemplate.opsForList().range(key, -2, 2)

从结果看:这样就不难理解了,从索引倒数第2个(即row为3),到索引第3个(即row为3)

6.2、stringRedisTemplate.opsForList().range(key, -4, 3)

从结果看:这样就不难理解了,从索引倒数第4个(即row为1),到索引第3个(即row为4)

6.3、stringRedisTemplate.opsForList().range(key, -4, 5)

从结果看:从索引倒数第4个(即row为1),到索引第5个(即row为6)

结论:按顺序超出是没问题的

标签: mysql redis

热门推荐