前言:本文档使用的是 SpringBoot,如果是 Spring 还需要在 MyBatis 配置 xml 中配置拦截器,并且 PageHelper 是针对 MyBatis 的,MyBatis 的集成不在本文档中叙述,请先集成 MyBatis。

一、引入PageHelper分页插件

引入的方式有两种,可以是导入Jar包,也可以使用 Maven 来构建,本文档将使用 Maven 来构建项目,如果你希望使用导入Jar包的方式进行集成,请从下面的链接下载Jar包:

  在 pox.xml 中添加PageHelper分页插件依赖

<!-- 分页插件pagehelper -->
<dependency>
<groupId>com.github.pagehelper</groupId>
<artifactId>pagehelper-spring-boot-starter</artifactId>
<version>1.2.10</version>
</dependency>

由于是SpringBoot项目,这里使用 pagehelper-spring-boot-starter ,如果是 spring 应使用 pagehelper

二、配置application.yml

# 分页配置

 pagehelper:
helper-dialect: mysql
reasonable: true
support-methods-arguments: true
params: count=countSql

改代码不加入,程序也可以正常运行,请根据实际情况进行添加。

三、在service层中使用PageHelper插件

(1)最简单的分页查询,直接传入

 public List<Article> selectArticleListByTag(TTag tag, int page, int rows) {
//使用分页插件,核心代码就这一行,页数、每页行数
PageHelper.startPage(page, rows);
//在 mapper.xml 中不要加 limit 分页,插件会自动拦截和添加 limit 分页
return articleMapper.selectArticleListByTag(tag);
}

  分页的同时,获取总数量,从而计算总页数

(2)EasyUI为例

  由于我使用了EasyUI,DataGrid控件的分页需要返回总行数,所以拿来展示比较经典

  先定义一个 Page 变量,这个类在com.github.pagehelper.Page,然后依然是 PageHelper.startPage(page, rows),然后进行正常的查询,在查询后pages.getTotal()就可以获取到总行数了,拿到总行数,就可以计算出总页数

  EasyUIDataGrid.java:

 package com.sun123.springboot.entity.easyui;

 import java.util.List;

 public class EasyUIDataGrid {
//当前页显示的数据 ?表示任意类型
private List<?> rows;
//表中总个数,不是总页数
private long total; public List<?> getRows() {
return rows;
} public void setRows(List<?> rows) {
this.rows = rows;
} public long getTotal() {
return total;
} public void setTotal(long total) {
this.total = total;
}
}

  UserService.java:

     //查询所有学生信息
EasyUIDataGrid showAllStudents(int page, int rows);

  UserServiceImpl.java:

     public EasyUIDataGrid showAllStudents(int page, int rows) {
EasyUIDataGrid dataGrid = new EasyUIDataGrid();
Page pages = PageHelper.startPage(page,rows);
List<User> userList = userMapper.selectByExample(null);
dataGrid.setRows(userList);
dataGrid.setTotal(pages.getTotal());
return dataGrid;
}

  AdminController.java:

     @PostMapping("/showAllStudents")
@ResponseBody
public EasyUIDataGrid showAllStudent(int page, int rows){
EasyUIDataGrid dataGrid = userService.showAllStudents(page, rows);
return dataGrid;
}

四、关于页数传入异常的情况

  有同学会担心,如果传入的页数是负数或者大于总页数会不会报错?是否需要进行边界检查?

  其实,如果传入的页数是负数,PageHelper 会展示第一页的数据;如果传入的页数大于总页数,PageHelper会展示最后一页的数据。并不会报错,所以使用这个插件比较省心,不用担心异常的页数传入导致业务抛出异常。

参考:https://www.neilren.com/Article/1003276

SpringBoot 使用 MyBatis 分页插件 PageHelper 进行分页查询的更多相关文章

  1. ssm下使用分页插件PageHelper进行分页

    1. 导入maven依赖: <dependency> <groupId>com.github.pagehelper</groupId> <artifactId ...

  2. 基于Mybatis分页插件PageHelper

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

  3. SpringBoot集成MyBatis的分页插件 PageHelper

    首先说说MyBatis框架的PageHelper插件吧,它是一个非常好用的分页插件,通常我们的项目中如果集成了MyBatis的话,几乎都会用到它,因为分页的业务逻辑说复杂也不复杂,但是有插件我们何乐而 ...

  4. SpringBoot添加对Mybatis分页插件PageHelper的支持

    1.修改maven配置文件pom.xml,添加对pageHelper的支持: <!--pagehelper--> <dependency> <groupId>com ...

  5. SpringBoot Mybatis 分页插件PageHelper

    添加maven配置: <!-- 分布插件 --> <dependency> <groupId>com.github.pagehelper</groupId&g ...

  6. Springboot集成mybatis通用Mapper与分页插件PageHelper

    插件介绍 通用 Mapper 是一个可以实现任意 MyBatis 通用方法的框架,项目提供了常规的增删改查操作以及 Example 相关的单表操作.通用 Mapper 是为了解决 MyBatis 使用 ...

  7. Mybatis的分页插件PageHelper

    Mybatis的分页插件PageHelper 项目地址:http://git.oschina.net/free/Mybatis_PageHelper  文档地址:http://git.oschina. ...

  8. mybatis分页插件PageHelper的使用(转)

    Mybatis 的分页插件PageHelper-4.1.1的使用 Mybatis 的分页插件 PageHelper 项目地址:http://git.oschina.net/free/Mybatis_P ...

  9. MyBatis学习总结_17_Mybatis分页插件PageHelper

    如果你也在用Mybatis,建议尝试该分页插件,这一定是最方便使用的分页插件. 分页插件支持任何复杂的单表.多表分页,部分特殊情况请看重要提示. 想要使用分页插件?请看如何使用分页插件. 物理分页 该 ...

随机推荐

  1. Unity 后处理堆

    Unity安装后处理的过程:windows---PacageManager---Post Processing Post Processing后处理堆需要知道要修改那个相机渲染的内容,先定位到相机,再 ...

  2. mysql 变量定义 sql查询

    SET @idnoStr:='"idNo":"'; SELECT LOCATE(@idnoStr, param_array), LOCATE('",', par ...

  3. 关于JAVA-JS-JSP之间传值的各种方法

    https://blog.csdn.net/murex_dustyone/article/details/52945552 这篇博文写的非常好,保存下来,一起学习

  4. Vue(基础七)_webpack使用工具(下)

    一.前言  1.webpack.config文件配置                                          2.webpack打包css文件                 ...

  5. socket编程 ------ UDP服务器

    void vLANcommunication( void *pvParameters ) { int32 listenfd; do{ listenfd = socket(AF_INET, SOCK_D ...

  6. jq实现百度图片移入移出内容提示框上下左右移动的效果

    闲来无聊,看到百度图片hover的时候提示框的效果,遂想试一试自己能否实现. 百度图片hover的效果: 需求: 1. 当鼠标从图片上部移入的时候,提示框从上部移到正常位置.从上部移出的时候,提示框从 ...

  7. 运用tp5上传图片,并生成缩略图

    最近想做个相册,需要用到上传图像,并且考虑到性能问题,还要生成缩略图,就学习下.在网上看了很多大神写的文章,经过各种调试总算出来了,分享下.不好之处,多多指教 ​ ​ ps:运用tp5图片类生成缩略图 ...

  8. OpenCV编译以及QT Creator配置

    OpenCV编译以及QT Creator配置 在进行编译前,需下载以下工具和源码: CMake ---- 用于编译: 下载地址; https://cmake.org/ 安装在D:\Program Fi ...

  9. windows wmi

    官网:https://msdn.microsoft.com/en-us/library/aa394132(v=vs.85).aspx WMI使用的WIN32_类库名:http://blog.csdn. ...

  10. docker的使用 -- windows

    1. 下载docker desktop https://www.docker.com/products/docker-desktop 更多操作指令 ps: 值得注意的是,刚下载下来的docker只能在 ...