手动分页实现

需求背景:

在实际项目开发中,有时候需要对从数据库查出的数据进行添加、修改、拼接等一系列处理,处理完成后再对数据进行分页。这时候pageHelper就不再适用了,因为pageHelper是对查询sql的修改,添加分页语句实现的分页。这时候,就需要自己手动分页。
代码:
		Integer page = pageBean.getPage();
        Integer size = pageBean.getSize();
        List 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。

你可能感兴趣的:(pageHelper)