利用Mybatis 的 PageHelper进行分页,分页数据不正确问题

Q&A:之前写了一个项目,用PageHelper进行分页。分页后中途换了PageInfo中存储的List数据,分页数据就丢失了。因为调用PageHelper.startPage()进行分页,然后紧挨着的这个Mapper语句就会进行分页,紧接着new PageInfo<>(),放入该分页后的数据的集合,这样便会正常的获得分页数据信息。而为了修改返回数据,将该list进行了切换,导致分页数据获取异常,解决方法如下:

public PageInfo findXxxx(xxxx){
 	PageHelper.startPage(pageNumber, pageSize);
 	List<Xxxx> list = xxxMapper.selectByXxxx(xxx);
	PageInfo tempPageInfo = new PageInfo<>(list);
 	//进行你的操作获得新的list
 	List<XxxxVO> newList = new ArrayList();
 	......
 	//将tempPageInfo中存储的分页信息赋值给新的PageInfo,并把新的newList 存储到新的PageInfo中
 	return newPage(tempPageInfo,newList);
 }
 
private static <T> PageInfo newPage(PageInfo old,List<T> newList){
        PageInfo<T> pageInfo = new PageInfo<>();
        pageInfo.setList(newList);
        pageInfo.setPageNum(old.getPageNum());
        pageInfo.setTotal(old.getTotal());
        pageInfo.setPageSize(old.getPageSize());
        pageInfo.setSize(old.getSize());
        pageInfo.setEndRow(old.getEndRow());
        pageInfo.setStartRow(old.getStartRow());
        pageInfo.setPages(old.getPages());
        pageInfo.setPrePage(old.getPrePage());
        pageInfo.setNextPage(old.getNextPage());
        pageInfo.setIsFirstPage(old.isIsFirstPage());
        pageInfo.setIsLastPage(old.isIsLastPage());
        pageInfo.setHasPreviousPage(old.isHasPreviousPage());
        pageInfo.setHasNextPage(old.isHasNextPage());
        pageInfo.setNavigatePages(old.getNavigatePages());
        pageInfo.setNavigatepageNums(old.getNavigatepageNums());
        pageInfo.setNavigateFirstPage(old.getNavigateFirstPage());
        pageInfo.setNavigateLastPage(old.getNavigateLastPage());
        return pageInfo;
    }
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值