• 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!!!

  • 相关阅读:
    Eureka的工作原理以及它与ZooKeeper的区别
    利用javascript判断文件是否存在
    带jsk证书,请求https接口
    C# .net 数组倒序排序
    C#中ArrayList和string,string[]数组的转换
    C#中遍历ArrayList的三种方法
    求其中同一个主叫号码的两次通话之间间隔大于10秒的通话记录ID
    启动tomcat时,一直卡在Deploying web application directory这块的解决方案
    Linux下修改Mysql的用(root的密码及修改root登录权限
    启动MySql提示:The server quit without updating PID file(…)失败
  • 原文地址:https://www.cnblogs.com/Fzeng/p/14766725.html
Copyright © 2020-2023  润新知