使用java8实现stream流分页

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.总结:

个人认为这只是看得到的优化,里面应该还有具体的细节没有优化到,还需要继续努力。

你可能感兴趣的:(Java,Java8之Stream流操作,java,redis)