java中分页插件怎么使用方法_Mybatis分页插件使用方法详解

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

1.分页插件简介

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

2.分页插件的使用

2.1导入maven依赖

com.github.pagehelper

pagehelper

最新版本

2.2 添加配置

1.在mybatis的config配置文件中添加拦截器

2.或者在spring配置中添加

params=value1

这两种方式不能同时用

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 list(orderrequest orderrequest){

//设置默认分页信息 pageservice的方法

setdefaultpageinfo(orderrequest);

//查出order列表

list orderlist = ordermapper.selectlist();

//将entity的列表分页

pageinfo orderpageinfo = new pageinfo<>(orderlist);

//连续显示5页与上面的二选一

//pageinfo orderpageinfo = new pageinfo<>(orderlist,5);

//定义一个数据传输对象dtolist

list 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 dtopageinfo = new pageinfo<>(dtolist);

//连续显示5页 与上面的二选一

//pageinfo orderpageinfo = new pageinfo<>(orderlist,5);

//将entity的分页信息复制给dtopageinfo上

pageutils.copyproperties(orderpageinfo, dtopageinfo);

return dtopageinfo;

}

}

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

如您对本文有疑问或者有任何想说的,请点击进行留言回复,万千网友为您解惑!

  • 0
    点赞
  • 0
    收藏
    觉得还不错? 一键收藏
  • 0
    评论

“相关推荐”对你有帮助么?

  • 非常没帮助
  • 没帮助
  • 一般
  • 有帮助
  • 非常有帮助
提交
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值