Mybatis分页插件使用方法详解
本文实例为大家分享了Mybatis分页插件使用的具体代码,供大家参考,具体内容如下
1.分页插件简介
pagehelper源码
都说这是史上最好用的分页插件,支持多种数据库以多种方式分页。
2.分页插件的使用
2.1导入maven依赖
com.github.pagehelper pagehelper 最新版本
2.2添加配置
1.在mybatis的config配置文件中添加拦截器
2.或者在spring配置中添加
params=value1
这两种方式不能同时用
3.在代码中的使用
3.1设置一个基础的请求类
publicclassBaseRequestimplementsSerializable{
privatestaticfinallongserialVersionUID=1193444819529643410L;
privateIntegerpageNum;//页数
privateIntegerpageSize;//每页行数
privateBooleancount;//是否查询总条数
publicIntegergetPageNum(){
returnpageNum;
}
publicvoidsetPageNum(IntegerpageNum){
this.pageNum=pageNum;
}
publicIntegergetPageSize(){
returnpageSize;
}
publicvoidsetPageSize(IntegerpageSize){
this.pageSize=pageSize;
}
publicBooleangetCount(){
returncount;
}
publicvoidsetCount(Booleancount){
this.count=count;
}
@Override
publicStringtoString(){
return"BaseRequest{"+
"pageNum="+pageNum+
",pageSize="+pageSize+
'}';
}
}
3.2设置一个基础的PageService接口
让每个service去实现这个接口来设置分页的初始值
publicinterfacePageService{
defaultvoidsetDefaultPageInfo(BaseRequestbaseRequest){
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=newBaseRequest();
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复制分页属性
publicclassPageUtils{
publicstaticvoidcopyProperties(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实现类中
importcom.github.pagehelper.PageInfo;
importcom.javxuan.common.util.PageUtils;
importcom.javxuan.order.entity.Order;
importcom.javxuan.order.response.OrderDto;
importcom.javxuan.order.service.PageService;
importorg.springframework.beans.BeanUtils;
importorg.springframework.beans.factory.annotation.Autowired;
importjava.util.ArrayList;
publicclassOrderServcieImplimplementsIOrderServcie,PageService{
@Autowired
IOrderMapperorderMapper;
@GetMapping("/order")
publicPageInfolist(OrderRequestorderRequest){
//设置默认分页信息PageService的方法
setDefaultPageInfo(orderRequest);
//查出order列表
ListorderList=orderMapper.selectList();
//将entity的列表分页
PageInfoorderPageInfo=newPageInfo<>(orderList);
//连续显示5页与上面的二选一
//PageInfoorderPageInfo=newPageInfo<>(orderList,5);
//定义一个数据传输对象dtoList
ListdtoList=newArrayList<>();
if(null==orderList||orderList.size<=0){
returnnull;
}
//给dtoList加值
for(Orderorder:orderList){
OrderDtodto=newOrderDto();
//将entity的属性值复制给dto上
BeanUtils.copyProperties(order,dto);
dtoList.add(dto);
}
//给dto分页
PageInfodtoPageInfo=newPageInfo<>(dtoList);
//连续显示5页与上面的二选一
//PageInfoorderPageInfo=newPageInfo<>(orderList,5);
//将entity的分页信息复制给dtoPageInfo上
PageUtils.copyProperties(orderPageInfo,dtoPageInfo);
returndtoPageInfo;
}
}
以上就是本文的全部内容,希望对大家的学习有所帮助,也希望大家多多支持毛票票。
声明:本文内容来源于网络,版权归原作者所有,内容由互联网用户自发贡献自行上传,本网站不拥有所有权,未作人工编辑处理,也不承担相关法律责任。如果您发现有涉嫌版权的内容,欢迎发送邮件至:czq8825#qq.com(发邮件时,请将#更换为@)进行举报,并提供相关证据,一经查实,本站将立刻删除涉嫌侵权内容。