理解 Mybatis的分页插件 PageHelper  Mybatis + SpringMVC + Maven实现分页查询 (推荐采用的插件是PageHelper)

先看一下之前的这篇博客,这里推荐了 Mybatis 的分页方法。

按照上面的方法设置后,确实实现了分页,可是 对于其原理还不甚理解,对其加以了分析之后,本篇博客,则用来说明使用该插件的过程中产生的疑惑。

java 中的实现代码:

public PageInfo<Users> selectUsersByIsaByPage(Integer isapproval,Integer pageNo,Integer pageSize)
  {
      pageNo = pageNo == null?1:pageNo;
      pageSize = pageSize == null?10:pageSize;
      PageHelper.startPage(pageNo, pageSize);
      List<Users> list = userDao.selectUsersByIsapproval(isapproval);
      //用PageInfo对结果进行包装
      PageInfo<Users> page = new PageInfo<Users>(list);
      //测试PageInfo全部属性
      System.out.println(page.toString());
      return page;
  }

1、实现

  我们只需要使用 PageHelper.startPage(pageNo,pageSize) 函数来指定 pageNo(第几页) 和 pageSize(每页显示几条记录)两个参数,然后调用原来的查询,就进行了分页,最后返回的是list,转换成 PageBean 类型的结果即可,前台就可以根据 PageBean 来取得对应需要的值了

2、关于 PageBean

  分页查询结果 返回的是一个 page 对象,而Page 对象 继承自ArrayList,但是如果我们直接返回 ArrayList 的话,比如在 JSON 处理Page 类型的结果时,会被当成 List 来Json 格式化 会丢弃掉 Page 对象的所有扩展属性。为了保留这些属性,所以将分页Page类型装换成我们自己定义的PageBean, 自己定义个没有继承ArrayList 的PageBean ,包含一个List 的属性来保存分页结果。

  PageInfo 是插件作者给我们提供的一个参考例子,当然可以直接使用,也可以 根据自己的项目情况,定义一个PageBean来保存分页之后的结果,需要哪些属性,就加入哪些属性。

  我只想要 Page 里面的list 就是查询到的对象……

3、PageHelper 的原理是基于 拦截器实现的。

  拦截器的配置有两种方式,一种是mybatis 的配置文件中配置,一种是直接在Spring 的配置文件中进行

4、我有一个重要的 bug,暂时还不知道原因

  我的项目中使用到了 AOP的,(不确定原因是不是这里)

  比如,我有一个对象 dict,对象中有一个属性user来表示当前用户,如果用户不存在,则会去数据库查询。于是 我的分页查询 dict,结果就是拦截器拦截的查询是 用户,结果放在了PageInfo 中,而不仅仅是简单的dict 的分页……