解决PageHelper分页不正常,pages始终等于1,total 始终等于pageSize的问题

本文介绍了使用PageHelper进行分页查询时遇到的问题,即pages始终为1,total始终等于pageSize。问题根源在于对查询结果list进行了额外的操作,导致分页信息失效。解决方法是避免对数据库查询结果进行修改,或者采取更合理的处理方式来确保分页正确性。

摘要生成于 C知道 ,由 DeepSeek-R1 满血版支持, 前往体验 >

解决PageHelper分页不正常,pages始终等于1,total 始终等于pageSize的问题

问题

pages始终等于1,total 始终等于pageSize

image-20200912095549024

原因

原因是我在查询到list数据之后,对list做了操作,导致分页不正常

// 这是service层的类
public PageInfo<TUiWork> getAllByPagination(Integer pageNum, Integer pageSize) {
    PageHelper.startPage(pageNum, pageSize);
    List<TUiWork> workList = workMapper.getAll();
    
    // 问题就在这里,我对workList做了操作
    List<TUiWork> newWorkList = new ArrayList<>();
    for (TUiWork work : workList) {
        List<String> imageUrlList = getImageUrlListByIds(work.getImageId());
        work.setImageUrls(imageUrlList);
        newWorkList.add(work);
    }

    // 把新的list传递给了PageInfo,导致分页不正常
    PageInfo<TUiWork> tUiWorkPageInfo = new PageInfo<>(newWorkList);
    return tUiWorkPageInfo;
}

解决

解决方法就是从数据库中查询出的list数据不要做其他操作,直接把list给PageInfo(这种做法不推荐,下面有更好的做法)

// 这是service层的类
public PageInfo<TUiWork> getAllByPagination(Integer pageNum, Integer pageSize) {
    PageHelper.startPage(pageNum, pageSize);
    List<TUiWork> workList = workMapper.getAll();
    PageInfo<TUiWork> tUiWorkPageInfo = new PageInfo<>(workList);
    return tUiWorkPageInfo;
}

image-20200912093915935

然而上面这种方法并不推荐,因为我们有的业务确实需要对查询后的list进行操作

推荐下面这种做法

// 这是service层的类
public PageInfo<TUiWork> getAllByPagination(Integer pageNum, Integer pageSize) {
    PageHelper.startPage(pageNum, pageSize);
    List<TUiWork> workList = workMapper.getAll();
    // 对list做一些操作,新的list是newWorkList
    List<TUiWork> newWorkList = new ArrayList<>();
    for (TUiWork work : workList) {
        List<String> imageUrlList = getImageUrlListByIds(work.getImageId());
        work.setImageUrls(imageUrlList);
        newWorkList.add(work);
    }

    // 这里还是对数据中查询的list数据workList做分页
    PageInfo<TUiWork> tUiWorkPageInfo = new PageInfo<>(workList);
    // 重新设置PageInfo的list即可,把新的list数据newWorkList设置到PageInfo
    tUiWorkPageInfo.setList(newWorkList);
    
    return tUiWorkPageInfo;
}
评论 7
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值