结论(具体测试数据请往下看)
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); } listrange = 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.3、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)
结论:按顺序超出是没问题的