需求背景:
在实际项目开发中,有时候需要对从数据库查出的数据进行添加、修改、拼接等一系列处理,处理完成后再对数据进行分页。这时候pageHelper就不再适用了,因为pageHelper是对查询sql的修改,添加分页语句实现的分页。这时候,就需要自己手动分页。
代码:
Integer page = pageBean.getPage();
Integer size = pageBean.getSize();
List<HistoryOrderVO> responseList = new ArrayList<>();
Integer listSize = historyOrderVOList.size();
responseList = historyOrderVOList.subList((page-1)*size > listSize ? listSize: (page-1)*size, page*size > listSize ? listSize: page*size);
return new PageResponseVO(MessageCode.SUCCESS.getStatus(),MessageCode.SUCCESS.getMsg(),responseList,Long.valueOf(listSize));
说明:
historyOrderVOList为所有的数据集合,responseList 为要返回给前端的分页的集合,利用分页参数用subList()方法将集合拆分。page为页码,size为每页容量。
使用时需要判断传入的page和size是否超过数据集合的大小,否则会出现arraysOutOfIndexException。