mybatis pagehelper手动设置pages属性不生效

环境: springboot+mybatis, 其中使用了pagehelp插件

依赖如下: 

        
            com.github.pagehelper
            pagehelper-spring-boot-starter
            1.2.3
            
                
                    org.mybatis.spring.boot
                    mybatis-spring-boot-starter
                
            
        

问题描述:

手动构建Page对象, 设置的pages属性不生效, 例如设置值为3, 获取的时候依然是0; 

原因: 构造的Page对象没有设置pageSize属性.  调用page对象的setTotal()方法时, 该方法内部根据pageSize属性重置了pages属性的值.

Page对象的setTotal方法源码如下:

    public void setTotal(long total) {
        this.total = total;
        if (total == -1) {
            pages = 1;
            return;
        }
        // 如果pageSize<=0, 则直接设置pages=0; pageSize默认为0
        if (pageSize > 0) {
            pages = (int) (total / pageSize + ((total % pageSize == 0) ? 0 : 1));
        } else {
            pages = 0;
        }
        //分页合理化,针对不合理的页码自动处理
        if ((reasonable != null && reasonable) && pageNum > pages) {
            pageNum = pages;
            calculateStartAndEndRow();
        }
    }

 

手动构造Page对象代码如下:

        // 返回值page对象
        Page pageResult = new Page<>();
        // 不设置pageSize,setPages方法调用无效, setTotal方法覆盖了pageResult的pages属性
        // 解决方案: 1. 设置pageSize属性在调用setTotal方法之前; 2. setTotal方法调用之后在设置pages属性
        pageResult.setPageSize(pageDto.getPageSize());
        pageResult.setPages(totalPages);
        pageResult.setTotal(totalElements);
        pageResult.addAll(studyRecordVoList);

 

你可能感兴趣的:(mybatis)