RedisTemplate 分页

利用spring redis的RedisTemplate进行分页:

场景:

现有项目若干,根据项目的创建时间(createTime)进行降序读取:

存储结构:

key:proList(list)

存放项目id

[

110,

111,

112

]

key:proInfo:{proId}(hash)

pro:110

{

id:110,

proName:p110,

createTime:"2019:01:03 04:23:35"

}

 

 

pro:111

{

id:111,

proName:p1111,

createTime:"2019:01:03 04:24:56"

}

 

 

 

pro:112

{

id:112,

proName:p112,

createTime:"2019:01:03 04:25:35"

}

 

分页方法:

public static <T> List<T> sortPageList(String key, String subKey, String by, boolean isDesc, boolean isAlpha, int off, int num) throws Exception {
SortQueryBuilder<String> builder = SortQueryBuilder.sort(key);
builder.by(subKey + "*->" + by);
builder.get("#");
builder.alphabetical(isAlpha);
if (isDesc)
builder.order(SortParameters.Order.DESC);
builder.limit(off, num);
List<String> cks = redisTemplate.sort(builder.build());
List<T> result = new ArrayList<T>();
for (String ck : cks) {
//得到项目对象 by(subKey+ck);
}
return result;

}

调用方法:
sortPageList("proList","pro:","createTime",true,false,0,20)//本次分页取前20条数据0-->19
需要注意到的是isAlpha参数

如果设置为true

将按照字幕顺序进行排序。

 

  • 0
    点赞
  • 0
    收藏
    觉得还不错? 一键收藏
  • 3
    评论
回答: 在给定的代码中,redisTemplate分页的方法是通过传入pageNum和pageSize两个参数来实现的。在getKeyDefineList0方法中,首先根据传入的keyTemplate格式化key,然后根据pageNum和pageSize计算出查询的起始位置和结束位置。接下来,使用Redis的SCAN命令扫描符合条件的key,并将结果存放在一个LinkedHashSet中。最后,返回该集合作为分页查询的结果。\[1\] 另外,还有一个sortPageList方法也可以实现redisTemplate分页查询。在该方法中,通过SortQueryBuilder构建排序查询的条件,包括key、subKey、by等参数。然后使用redisTemplate的sort方法进行排序查询,并通过设置limit参数来实现分页功能。最后,将查询结果存放在一个List中并返回。\[3\] 总结起来,redisTemplate可以通过不同的方法实现分页查询,可以根据具体的需求选择合适的方法来进行操作。 #### 引用[.reference_title] - *1* *2* [Sring Redis实现分页查询key keytemplate列表](https://blog.csdn.net/xys0415/article/details/130080212)[target="_blank" data-report-click={"spm":"1018.2226.3001.9630","extra":{"utm_source":"vip_chatgpt_common_search_pc_result","utm_medium":"distribute.pc_search_result.none-task-cask-2~all~insert_cask~default-1-null.142^v91^koosearch_v1,239^v3^insert_chatgpt"}} ] [.reference_item] - *3* [RedisTemplate 分页](https://blog.csdn.net/u014783753/article/details/53995510)[target="_blank" data-report-click={"spm":"1018.2226.3001.9630","extra":{"utm_source":"vip_chatgpt_common_search_pc_result","utm_medium":"distribute.pc_search_result.none-task-cask-2~all~insert_cask~default-1-null.142^v91^koosearch_v1,239^v3^insert_chatgpt"}} ] [.reference_item] [ .reference_list ]
评论 3
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值