对于一些与时间或日期密切关联的应用,分页是基于时间的。
比如博客系统,用户可能只对对特定时间段的文章感兴趣,例如,他想查看在2023年至2025年发表的文章,诸如此类。
可以利用reids的zset来实现这个功能。
package com.foxbill.redisinaction;
import redis.clients.jedis.Jedis;
import java.util.List;
import java.util.stream.Collectors;
/**
* 时间线
*/
public class Chapter24 {
static private String KEY_TIMELINE = "Chapter24:timeline";
static public void start(Jedis jedis) {
cleanData(jedis);
initData(jedis);
//
long total = count(jedis);
System.out.printf("total: %d\n", total);
//
int page=2;
int pageSize=10;
List<String> pageData = get(jedis, page, pageSize);
String strData = pageData.stream().collect(Collectors.joining(","));
System.out.printf("page %d\n%s\n",page,strData);
page=3;
pageData = get(jedis, page, pageSize);
strData = pageData.stream().collect(Collectors.joining(","));
System.out.printf("page %d\n%s\n",page,strData);
}
//清除数据
private static void cleanData(Jedis jedis) {
jedis.del(KEY_TIMELINE);
}
//初始化数据
private static void initData(Jedis jedis) {
long begintTimeStamp = 1748702000;
for (int i = 0; i < 34; i++) {
jedis.zadd(KEY_TIMELINE,begintTimeStamp+1000*i,"item:"+String.valueOf(i));
}
}
private static List<String> get(Jedis jedis,int page,int pageSize) {
int start = (page - 1) * pageSize;
int end = page * pageSize-1;
List<String> result = jedis.zrange(KEY_TIMELINE,start,end);
return result;
}
private static long count(Jedis jedis) {
long llen = jedis.zcard(KEY_TIMELINE);
return llen;
}
}

被折叠的 条评论
为什么被折叠?



