引言

  对于使用Mybatis时,最头痛的就是写分页,需要先写一个查询count的select语句,然后再写一个真正分页查询的语句,当查询条件多了之后,会发现真不想花双倍的时间写count和select。

  PageHelper分页实现原理说明

  1. //设置分页信息保存到threadlocal中
  2. PageHelper.startPage(1, 10);
  3. //紧跟着的第一个select方法会被分页,contryMapper会被PageInterceptor截拦,截拦器会从threadlocal中取出分页信息,把分页信息加到sql语句中,实现了分页查旬
  4. List<Country> list = countryMapper.selectIf(1);
  5. PageHelper.startPage(currentPage, pageSize);

  其实一开始看到这段代码时候,我觉得应该是内存分页。其实插件对mybatis执行流程进行了增强,添加了limit以及count查询,属于物理分页。

  count查询,其实是PageHelper帮助我们生成的一个MappedStatement内存对象,它可以免去我们在XXXMapper.xml内单独声明一个sqlcount查询,我们只需要写一个sql分页业务查询即可。

PageHelper部分源码

解析sql,并增加分页参数占位符,或者生成count查询的sql,都依靠Parser来完成。

  1. public class MysqlParser extends AbstractParser {
  2. @Override
  3. public String getPageSql(String sql) {
  4. StringBuilder sqlBuilder = new StringBuilder(sql.length() + 14);
  5. sqlBuilder.append(sql);
  6. sqlBuilder.append(" limit ?,? ");
  7. return sqlBuilder.toString();
  8. }
  9.  
  10. @Override
  11. public Map<String, Object> setPageParameter(MappedStatement ms, Object parameterObject, BoundSql boundSql, Page<?> page) {
  12. Map<String, Object> paramMap = super.setPageParameter(ms, parameterObject, boundSql, page);
  13. paramMap.put(PAGEPARAMETER_FIRST, page.getStartRow());
  14. paramMap.put(PAGEPARAMETER_SECOND, page.getPageSize());
  15. return paramMap;
  16. }
  17. }
  1. public abstract class AbstractParser implements Parser, Constant {
  2. public String getCountSql(final String sql) {
  3. return sqlParser.getSmartCountSql(sql);
  4. }
  5. }

PageHelper实战代码

  1. <!--pageHelper分页插件 -->
  2. <dependency>
  3. <groupId>com.github.pagehelper</groupId>
  4. <artifactId>pagehelper-spring-boot-starter</artifactId>
  5. <version>1.1.1</version>
  6. </dependency>
  1. 分页查询
  1. /**
  2. * 分页查询
  3. * @return
  4. */
  5. @RequestMapping("/GetStudentListByPage")
  6. public List<Student> GetStudentListByPage(@RequestParam(required = false, defaultValue = "1") int pageIndex,
  7. @RequestParam(required = false, defaultValue = "10") int pageSize){
  8. Page page = PageHelper.startPage(pageIndex, pageSize);
  9. List<Student> students = studentMapper.list();
  10. for(Student student : students) {
  11. System.out.println(student.getName());
  12. }
  13. System.out.println("当前页码:"+page.getPageNum());
  14. System.out.println("当前页数:"+page.getPageSize());
  15. System.out.println("总页数:"+page.getPages());
  16. System.out.println("总条数:"+page.getTotal());
  17. System.out.println(page.toString());
  18. return students;
  19. }

测试

http://localhost:8080/GetStudentListByPage?pageIndex=1&pageSize=2

参考资料

https://my.oschina.net/zudajun/blog/745232
Mybatis分页插件PageHelper简单使用

https://www.cnblogs.com/lxl57610/p/7766146.html

https://www.jianshu.com/nb/5226994

Java SSM框架之MyBatis3(三)Mybatis分页插件PageHelper的更多相关文章

  1. Mybatis学习---Mybatis分页插件 - PageHelper

    1. Mybatis分页插件 - PageHelper说明 如果你也在用Mybatis,建议尝试该分页插件,这个一定是最方便使用的分页插件. 该插件目前支持Oracle,Mysql,MariaDB,S ...

  2. 基于Mybatis分页插件PageHelper

    基于Mybatis分页插件PageHelper 1.分页插件使用 1.POM依赖 PageHelper的依赖如下.需要新的版本可以去maven上自行选择 <!-- PageHelper 插件分页 ...

  3. Mybatis分页插件PageHelper的配置和使用方法

     Mybatis分页插件PageHelper的配置和使用方法 前言 在web开发过程中涉及到表格时,例如dataTable,就会产生分页的需求,通常我们将分页方式分为两种:前端分页和后端分页. 前端分 ...

  4. Mybatis分页插件PageHelper使用

    一. Mybatis分页插件PageHelper使用  1.不使用插件如何分页: 使用mybatis实现: 1)接口: List<Student> selectStudent(Map< ...

  5. Mybatis分页插件PageHelper的实现

    Mybatis分页插件PageHelper的实现 前言 分页这个概念在做web网站的时候很多都会碰到 说它简单吧 其实也简单 小型的网站,完全可以自己写一个,首先查出数据库总条数,然后按照分页大小分为 ...

  6. Mybatis分页插件-PageHelper的使用

    转载:http://blog.csdn.net/u012728960/article/details/50791343 Mybatis分页插件-PageHelper的使用 怎样配置mybatis这里就 ...

  7. (转)淘淘商城系列——MyBatis分页插件(PageHelper)的使用以及商品列表展示

    http://blog.csdn.net/yerenyuan_pku/article/details/72774381 上文我们实现了展示后台页面的功能,而本文我们实现的主要功能是展示商品列表,大家要 ...

  8. springmvc mybatis 分页插件 pagehelper

    springmvc mybatis 分页插件 pagehelper 下载地址:pagehelper 4.2.1 , jsqlparser 0.9.5 https://github.com/pagehe ...

  9. MyBatis 分页插件PageHelper 后台报错

    今天遇到一个问题,使用MyBatis 分页插件PageHelper 进行排序分页后,能正常返回正确的结果,但后台却一直在报错 net.sf.jsqlparser.parser.ParseExcepti ...

随机推荐

  1. 【大数据应用技术】作业八|爬虫综合大作业Molly134

    本次作业的要求来自:https://edu.cnblogs.com/campus/gzcc/GZCC-16SE2/homework/3075 前言:本次作业是爬取CBO中国票房2010-2019年每年 ...

  2. iOS App之间常用的五种通信方式及适用场景总结

    iOS系统是相对封闭的系统,App各自在各自的沙盒(sandbox)中运行,每个App都只能读取iPhone上iOS系统为该应用程序程序创建的文件夹AppData下的内容,不能随意跨越自己的沙盒去访问 ...

  3. grunt入门讲解3:实例讲解使用 Gruntfile 配置任务

    这个Gruntfile 实例使用到了5个 Grunt 插件: grunt-contrib-uglify      grunt-contrib-qunitgrunt-contrib-concatgrun ...

  4. 开放地址法散列表ADT

    数据结构定义如下: typedef unsigned int Index; typedef Index Position; struct HashTbl; typedef struct HashTbl ...

  5. Beta阶段敏捷冲刺③

    1.提供当天站立式会议照片一张. 每个人的工作 (有work item 的ID),并将其记录在码云项目管理中: 1.1昨天已完成的工作. 姓名 昨天已完成的工作 徐璐琳 完善设置界面的功能 祁泽文 研 ...

  6. 软工网络15团队作业8——Beta阶段项目总结

    1.新成员 姓名 风格 擅长 角色 宣言 李家俊 乱写 都有所涉猎 测试 混就完事了 丁树乐 潇洒 与人沟通 测试 与其临渊羡鱼,不如退而结网 2.是否需要更换团队的PM 不需要 3.下一阶段需要改进 ...

  7. Beta阶段——4

    一.提供当天站立式会议照片一张: 二. 每个人的工作 (有work item 的ID) (1) 昨天已完成的工作: 完善了用户管理模式的功能 (2) 今天计划完成的工作: 对用户功能的添加. (3) ...

  8. 第九周(11.11-11.17)----Beta版本视频发布

    beta阶段视频发布地址: http://v.youku.com/v_show/id_XMTgxNjE2NzY3Mg==.html

  9. Delphi 判断一个字符串是否为数字

    //函 数 名: IsDigit//返 回 值: boolean//日       期:2011-03-01//参       数: String//功       能: 判断一个字符串是否为数字// ...

  10. NOI前训练日记

    向别人学习一波,记点流水帐.17.5.29开坑. 5.29 早晨看了道据说是树状数组优化DP的题(hdu5542),然后脑补了一个复杂度500^3的meet in the middle.然后死T... ...