这篇文章主要给大家介绍了关于redis中opsForList().range()的使用方法,文中通过实例代码以及图文介绍的非常详细,对大家学习或者使用redis具有一定的参考学习价值,需要的朋友可以参考下
测试stringRedisTemplate.opsForList().range(key, start, end)的使用
结论(具体测试数据请往下看)
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个——索引倒数第1个
4.2、stringRedisTemplate.opsForList().range(key, -3, -1)
从结果看:从索引倒数第3个——索引倒数第1个
4.3、stringRedisTemplate.opsForList().range(key, -3, -2)
从结果看:从索引倒数第3个——索引倒数第2个
4.4、stringRedisTemplate.opsForList().range(key, -2, -3)
从结果看:从索引倒数第2个——索引倒数第3个不行,从索引倒数第3个——索引倒数第2个可以。
结论:从索引倒数第N个开始,要按照顺序(即 -N、-(N-1)、-(N-2)、……、-1),逆序是不行的
5、测试从索引正数开始
5.1、stringRedisTemplate.opsForList().range(key, 0, 3)
从结果看:从索引第1个——索引第4个
5.2、stringRedisTemplate.opsForList().range(key, 1,2)
从结果看:从索引第2个——索引第3个
5.2、stringRedisTemplate.opsForList().range(key, 2,1)
从结果看:从索引第3个——索引第2个不行,从索引第2个——索引第3个可以
结论:从索引0开始,要按照顺序(即 0、1、2、……、N-1),逆序是不行的
6、测试索引倒数——索引正数(正数索引,下标 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)
结论:按顺序超出是没问题的
总结
到此这篇关于redis中opsForList().range()的使用方法详解的文章就介绍到这了,更多相关redis opsForList().range()的使用内容请搜索编程学习网以前的文章希望大家以后多多支持编程学习网!
本文标题为:redis中opsForList().range()的使用方法详解
基础教程推荐
- 如何将excel表格数据导入postgresql数据库 2023-07-20
- Mysql主从三种复制模式(异步复制,半同步复制,组复 2022-09-01
- Sql Server Management Studio连接Mysql的实现步骤 2023-07-29
- SQLServer 清理日志的实现 2023-07-29
- 【Redis】数据持久化 2023-09-12
- Python常见库matplotlib学习笔记之多个子图绘图 2023-07-27
- Mysql查询所有表和字段信息的方法 2023-07-26
- 关于MySQL中explain工具的使用 2023-07-27
- python中pandas库的iloc函数用法解析 2023-07-28
- Redis如何实现延迟队列 2023-07-13