欢迎您访问程序员文章站本站旨在为大家提供分享程序员计算机编程知识!
您现在的位置是: 首页  >  IT编程

Mybatis分页插件使用方法详解

程序员文章站 2024-02-26 11:36:34
本文实例为大家分享了mybatis分页插件使用的具体代码,供大家参考,具体内容如下 1.分页插件简介 pagehelper源码 都说这是史上最好用的分页插件,支持多...

本文实例为大家分享了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;
 }
}

以上就是本文的全部内容,希望对大家的学习有所帮助,也希望大家多多支持。