1.场景:
最近一段时间一直在做公司官网的项目,遇到的问题是官网需要通过请求来获取管理系统这边的数据,然后在官网那边进行分页展示。如果请求每次都来查库的话,就有可能直接把mysql给干掉了,所以想法是把数据分好页之后放到Redis中,然后请求直接去调Redis获取数据,再通过定时任务每天去更新Redis的数据。
2.思路:
一开始的想法就是把所有的数据查询出来,然后通过stream流来进行分页,但是后来我大哥看了一下,丢给我一句话:“可以优化”,在我就冥思苦想大半小时之后,终于想到了我能想到的办法,下面是我的两种处理方案
3.解决方案:
3.1方案1:Stream流(两次循环)
public static void main(String[] args) {
double pageSize = 6;
List<String> list = new ArrayList<>();
for (int page = 1; (page - 1) * pageSize < list.size(); page++) {
//分页数据
List pageList = list.stream().skip((long) ((page - 1) * pageSize))
.limit((long) pageSize)
.collect(Collectors.toList());
//存放到redis中
redisService.setObjectKey("数据页码"+page, pageData);
}
}
3.2方案2:for循环(一次循环)
double pageSize = 6;
List<String> list = new ArrayList<>();
for (int i = 0, page = 1; i < webDataList.size(); i = i + 6, page++) {
List<WebDataPo> list = webDataList.subList(i, Math.min(i + 6, webDataList.size()));
redisService.setObjectKey("数据页码" + page, new ArrayList<>(list));
}
4.总结:
个人认为这只是看得到的优化,里面应该还有具体的细节没有优化到,还需要继续努力。