Mybatis分页插件使用方法详解

作者:Javxuan 时间:2021-10-12 06:59:30 

本文实例为大家分享了Mybatis分页插件使用的具体代码,供大家参考,具体内容如下

1.分页插件简介

pagehelper源码

都说这是史上最好用的分页插件,支持多种数据库以多种方式分页。

2.分页插件的使用

2.1导入maven依赖


<dependency>
<groupId>com.github.pagehelper</groupId>
<artifactId>pagehelper</artifactId>
<version>最新版本</version>
</dependency>

2.2 添加配置

1.在mybatis的config配置文件中添加 * <plugin>


<!--
plugins在配置文件中的位置必须符合要求,否则会报错,顺序如下:
properties?, settings?,
typeAliases?, typeHandlers?,
objectFactory?,objectWrapperFactory?,
plugins?,
environments?, databaseIdProvider?, mappers?
-->
<plugins>
 <plugin interceptor="com.github.pagehelper.PageHelper">
  <property name="dialect" value="mysql"/>
  <!-- 该参数默认为false -->
  <!-- 设置为true时,会将RowBounds第一个参数offset当成pageNum页码使用 -->
  <!-- 和startPage中的pageNum效果一样-->
  <property name="offsetAsPageNum" value="true"/>
  <!-- 该参数默认为false -->
  <!-- 设置为true时,使用RowBounds分页会进行count查询 -->
  <property name="rowBoundsWithCount" value="true"/>
  <!-- 设置为true时,如果pageSize=0或者RowBounds.limit = 0就会查询出全部的结果 -->
  <!-- (相当于没有执行分页查询,但是返回结果仍然是Page类型)-->
  <property name="pageSizeZero" value="true"/>
  <!-- 3.3.0版本可用 - 分页参数合理化,默认false禁用 -->
  <!-- 启用合理化时,如果pageNum<1会查询第一页,如果pageNum>pages会查询最后一页 -->
  <!-- 禁用合理化时,如果pageNum<1或pageNum>pages会返回空数据 -->
  <property name="reasonable" value="false"/>
  <!-- 3.5.0版本可用 - 为了支持startPage(Object params)方法 -->
  <!-- 增加了一个`params`参数来配置参数映射,用于从Map或ServletRequest中取值 -->
  <!-- 可以配置pageNum,pageSize,count,pageSizeZero,reasonable,不配置映射的用默认值 -->
  <!-- 不理解该含义的前提下,不要随便复制该配置 -->
  <property name="params" value="pageNum=start;pageSize=limit;"/>
 </plugin>
</plugins>

2.或者在spring配置中添加


<bean id="sqlSessionFactory" class="org.mybatis.spring.SqlSessionFactoryBean">
<!-- 注意其他配置 -->
<property name="plugins">
<array>
 <bean class="com.github.pagehelper.PageInterceptor">
 <property name="properties">
  <!--使用下面的方式配置参数,一行配置一个 -->
  <value>
  params=value1
  </value>
 </property>
 </bean>
</array>
</property>
</bean>

这两种方式不能同时用

3.在代码中的使用

3.1设置一个基础的请求类


public class BaseRequest implements Serializable {

private static final long serialVersionUID = 1193444819529643410L;

private Integer pageNum;//页数
private Integer pageSize;//每页行数
private Boolean count;//是否查询总条数

public Integer getPageNum() {
 return pageNum;
}

public void setPageNum(Integer pageNum) {
 this.pageNum = pageNum;
}

public Integer getPageSize() {
 return pageSize;
}

public void setPageSize(Integer pageSize) {
 this.pageSize = pageSize;
}

public Boolean getCount() {
 return count;
}

public void setCount(Boolean count) {
 this.count = count;
}

@Override
public String toString() {
 return "BaseRequest{" +
   "pageNum=" + pageNum +
   ", pageSize=" + pageSize +
   '}';
}
}

3.2 设置一个基础的PageService 接口

让每个service 去实现这个接口来设置分页的初始值


public interface PageService {

default void setDefaultPageInfo(BaseRequest baseRequest) {
 if (null != baseRequest) {
  baseRequest.setPageNum(null == baseRequest.getPageNum() ? Constants.PAGE_NUM : baseRequest.getPageNum());
  baseRequest
    .setPageSize(null == baseRequest.getPageSize() ? Constants.PAGE_SIZE : baseRequest.getPageSize());
  baseRequest.setCount(null == baseRequest.getCount() ? Boolean.TRUE : baseRequest.getCount());
 } else {
  baseRequest = new BaseRequest();
  baseRequest.setPageNum(Constants.PAGE_NUM);
  baseRequest.setPageSize(Constants.PAGE_SIZE);
  baseRequest.setCount(Boolean.TRUE);
 }
 PageHelper.startPage(baseRequest.getPageNum(), baseRequest.getPageSize(),baseRequest.getCount());
}

}

3.3 如果做了数据转换这用来复制属性值(可选)

数据模型entity 只对应数据库表中的字段, 出参与入参 都是数据传输对象 dto , 从数据库中查出来的是entity而 接口返回的是dto 所要BeanUtils.copyProperties复制属性,和pageutils.copyProperties 复制分页属性


public class PageUtils {

public static void copyProperties(PageInfo<?> source, PageInfo<?> des) {
 des.setEndRow(source.getEndRow());
 des.setFirstPage(source.getFirstPage());
 des.setHasNextPage(source.isHasNextPage());
 des.setHasPreviousPage(source.isHasPreviousPage());
 des.setIsFirstPage(source.isIsFirstPage());
 des.setIsLastPage(source.isIsLastPage());
 des.setNavigatepageNums(source.getNavigatepageNums());
 des.setNavigatePages(source.getNavigatePages());
 des.setNextPage(source.getNextPage());
 des.setOrderBy(source.getOrderBy());
 des.setPageNum(source.getPageNum());
 des.setPages(source.getPages());
 des.setPageSize(source.getPageSize());
 des.setPrePage(source.getPrePage());
 des.setSize(source.getSize());
 des.setStartRow(source.getStartRow());
 des.setTotal(source.getTotal());
}
}

4.使用示例

在OrderService实现类中


import com.github.pagehelper.PageInfo;
import com.javxuan.common.util.PageUtils;
import com.javxuan.order.entity.Order;
import com.javxuan.order.response.OrderDto;
import com.javxuan.order.service.PageService;
import org.springframework.beans.BeanUtils;
import org.springframework.beans.factory.annotation.Autowired;

import java.util.ArrayList;

public class OrderServcieImpl implements IOrderServcie, PageService {

@Autowired
IOrderMapper orderMapper;

@GetMapping("/order")
public PageInfo<OrderDto> list(OrderRequest orderRequest){
 //设置默认分页信息 PageService的方法
 setDefaultPageInfo(orderRequest);

//查出order列表
 List<Order> orderList = orderMapper.selectList();
 //将entity的列表分页
 PageInfo<Order> orderPageInfo = new PageInfo<>(orderList);

//连续显示5页与上面的二选一
 //PageInfo<Order> orderPageInfo = new PageInfo<>(orderList,5);

//定义一个数据传输对象dtoList
 List<OrderDto> dtoList = new ArrayList<>();
 if(null==orderList || orderList.size<=0){
  return null;
 }

//给dtoList 加值
 for(Order order:orderList){
  OrderDto dto = new OrderDto();
  //将entity 的属性值 复制给dto上
  BeanUtils.copyProperties(order, dto);
  dtoList.add(dto);
 }

//给dto 分页
 PageInfo<OrderDto> dtoPageInfo = new PageInfo<>(dtoList);

//连续显示5页 与上面的二选一
 //PageInfo<Order> orderPageInfo = new PageInfo<>(orderList,5);

//将entity的分页信息复制给dtoPageInfo上
 PageUtils.copyProperties(orderPageInfo, dtoPageInfo);
 return dtoPageInfo;
}
}

来源:https://blog.csdn.net/u014297148/article/details/80444454

标签:Mybatis,分页插件
0
投稿

猜你喜欢

  • Java的idea连接mongodb数据库的详细教程

    2023-11-19 08:07:58
  • Android实现图片设置圆角形式

    2023-07-29 16:37:32
  • 图解Java线程的生命周期

    2022-04-12 15:16:10
  • Mybatis无法获取带有下划线前缀的字段的值问题

    2023-07-20 10:06:33
  • Java实现Http工具类的封装操作示例

    2021-08-14 10:27:57
  • Flutter runApp到渲染上屏分析详解

    2023-06-27 12:09:45
  • 浅析Java多线程同步synchronized

    2023-05-20 15:52:29
  • Java非侵入式API接口文档工具apigcc用法详解

    2023-11-24 10:01:00
  • Java接口的作用_动力节点Java学院整理

    2021-12-23 20:46:14
  • 关于Spring Data Jpa 自定义方法实现问题

    2023-11-28 10:08:32
  • C#正则表达式分解和转换IP地址实例(C#正则表达式大全 c#正则表达式语法)

    2023-07-17 07:11:25
  • Spring Boot 实现配置文件加解密原理

    2023-11-23 17:48:46
  • Java实现在PPT中创建SmartArt图形的示例代码

    2022-01-16 06:22:52
  • java实现简单的图书管理系统

    2022-11-25 03:30:11
  • 剑指Offer之Java算法习题精讲链表与字符串及数组

    2022-10-03 19:10:17
  • java使用websocket,并且获取HttpSession 源码分析(推荐)

    2023-08-04 17:38:05
  • 解决mybatis-plus自动配置的mapper.xml与java接口映射问题

    2023-08-25 04:16:02
  • Java线程池 ThreadPoolExecutor 详解

    2021-05-24 10:35:42
  • SpringBoot工程打包与运行的实现详解

    2023-11-10 23:51:28
  • Java的Spring框架下的AOP编程模式示例

    2023-11-02 00:52:25
  • asp之家 软件编程 m.aspxhome.com