Mybatis分页查询total中的坑

写在前面

今天用mybatis进行分页查询,大家应该都用过pageHelper这个插件,但是在计算总的数据数的时候,page.getTotal()总是返回0,要么就是返回pageSize(),今天给大家分享一下实用的解决办法

安装PageHelper

<dependency>
    <groupId>com.github.pagehelper</groupId>
    <artifactId>pagehelper</artifactId>
    <version>5.1.8</version>
</dependency>
<dependency>
    <groupId>com.github.jsqlparser</groupId>
    <artifactId>jsqlparser</artifactId>
    <version>1.2</version>
</dependency>

jsqlparser这个包官方的解释是:JsqlParser插件用来对于SQL语句进行解析和组装,将SQL语句关键词之间的内容用List进行保存,同时可以进行更改List的内容后重新组装成一个新的SQL语句
不知道不添加这个包对分页有没有影响(手动滑稽.jpg)

配置到spring和mybatis整合的配置文件中

在mybatis-config.xml文件中配置

<!--    配置pageHelper-->
    <plugins>
        <plugin interceptor="com.github.pagehelper.PageInterceptor">
            //设置数据库方言
            <property name="helperDialect" value="mysql"/>
            //开启查询合理化,比如数据只有100页,你查询150页,显示第100也
            //如果不开启的话,你查询150页就会显示空白  
            <property name="reasonable" value="true"/>
        </plugin>
    </plugins>

方法调用

使用PageHelper.startPage 静态方法调用startPage
特点:

  1. 静态方法,传递两个参数(当前页码,每页查询条数)
  2. 使用pageHelper 分页的时候,不再关注分页语句,查询全部的语句
  3. 自动的对PageHelper.startPage 方法下的第一个sql 查询进行分页
    PageHelper.startPage(1,5);
    //紧跟着的第一个select 方法会被分页
    List<User> list = userMapper.findAll();

获取total

public PageInfo findPage(int page,int pageSize){
  PageHelper.startPage(page,pageSize);
  List<User> List=userMapper.selectAll();
  PageInfo pageInfo = new PageInfo(list);
  return pageInfo;
 }
  

返回的信息就是pageInfo对象,该类是插件里的类,这个类里面的属性还是值得看一下

public class PageInfo<T> implements Serializable {
private static final long serialVersionUID = 1L;
//当前页
private int pageNum;
//每页的数量
private int pageSize;
//当前页的数量
private int size;
//由于startRow 和endRow 不常用,这里说个具体的用法
//可以在页面中"显示startRow 到endRow 共size 条数据"
//当前页面第一个元素在数据库中的行号
private int startRow;
//当前页面最后一个元素在数据库中的行号
private int endRow;
//总记录数
private long total;
//总页数
private int pages;
//结果集
private List<T> list;
//前一页
private int prePage;
//下一页
private int nextPage;
//是否为第一页
private boolean isFirstPage = false;
//是否为最后一页
private boolean isLastPage = false;
//是否有前一页
private boolean hasPreviousPage = false;
//是否有下一页
private boolean hasNextPage = false;
//导航页码数
private int navigatePages;
//所有导航页号
private int[] navigatepageNums;
//导航条上的第一页
private int navigateFirstPage;
//导航条上的最后一页
private int navigateLastPage;
}

在Controller层取出数据

//查询的总条数
long total = pageInfo.getTotal();
//取出数据
List list = pageInfo.getList():

我是末尾

祝大家的代码永无bug!!!

posted @ 2021-05-14 00:10  fengzeng  阅读(2475)  评论(0编辑  收藏  举报