本文實(shí)例為大家分享了Mybatis分頁(yè)插件使用的具體代碼,供大家參考,具體內(nèi)容如下
成都創(chuàng)新互聯(lián)公司從2013年創(chuàng)立,是專業(yè)互聯(lián)網(wǎng)技術(shù)服務(wù)公司,擁有項(xiàng)目成都網(wǎng)站設(shè)計(jì)、做網(wǎng)站、成都外貿(mào)網(wǎng)站建設(shè)公司網(wǎng)站策劃,項(xiàng)目實(shí)施與項(xiàng)目整合能力。我們以讓每一個(gè)夢(mèng)想脫穎而出為使命,1280元云夢(mèng)做網(wǎng)站,已為上家服務(wù),為云夢(mèng)各地企業(yè)和個(gè)人服務(wù),聯(lián)系電話:18980820575
1.分頁(yè)插件簡(jiǎn)介
pagehelper源碼
都說(shuō)這是史上最好用的分頁(yè)插件,支持多種數(shù)據(jù)庫(kù)以多種方式分頁(yè)。
2.分頁(yè)插件的使用
2.1導(dǎo)入maven依賴
com.github.pagehelper pagehelper 最新版本
2.2 添加配置
1.在mybatis的config配置文件中添加攔截器
2.或者在spring配置中添加
params=value1
這兩種方式不能同時(shí)用
3.在代碼中的使用
3.1設(shè)置一個(gè)基礎(chǔ)的請(qǐng)求類
public class BaseRequest implements Serializable { private static final long serialVersionUID = 1193444819529643410L; private Integer pageNum;//頁(yè)數(shù) private Integer pageSize;//每頁(yè)行數(shù) private Boolean count;//是否查詢總條數(shù) 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 設(shè)置一個(gè)基礎(chǔ)的PageService 接口
讓每個(gè)service 去實(shí)現(xiàn)這個(gè)接口來(lái)設(shè)置分頁(yè)的初始值
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 如果做了數(shù)據(jù)轉(zhuǎn)換這用來(lái)復(fù)制屬性值(可選)
數(shù)據(jù)模型entity 只對(duì)應(yīng)數(shù)據(jù)庫(kù)表中的字段, 出參與入?yún)?都是數(shù)據(jù)傳輸對(duì)象 dto , 從數(shù)據(jù)庫(kù)中查出來(lái)的是entity而 接口返回的是dto 所要BeanUtils.copyProperties復(fù)制屬性,和pageutils.copyProperties 復(fù)制分頁(yè)屬性
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實(shí)現(xiàn)類中
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 PageInfolist(OrderRequest orderRequest){ //設(shè)置默認(rèn)分頁(yè)信息 PageService的方法 setDefaultPageInfo(orderRequest); //查出order列表 List orderList = orderMapper.selectList(); //將entity的列表分頁(yè) PageInfo orderPageInfo = new PageInfo<>(orderList); //連續(xù)顯示5頁(yè)與上面的二選一 //PageInfo orderPageInfo = new PageInfo<>(orderList,5); //定義一個(gè)數(shù)據(jù)傳輸對(duì)象dtoList List dtoList = new ArrayList<>(); if(null==orderList || orderList.size<=0){ return null; } //給dtoList 加值 for(Order order:orderList){ OrderDto dto = new OrderDto(); //將entity 的屬性值 復(fù)制給dto上 BeanUtils.copyProperties(order, dto); dtoList.add(dto); } //給dto 分頁(yè) PageInfo dtoPageInfo = new PageInfo<>(dtoList); //連續(xù)顯示5頁(yè) 與上面的二選一 //PageInfo orderPageInfo = new PageInfo<>(orderList,5); //將entity的分頁(yè)信息復(fù)制給dtoPageInfo上 PageUtils.copyProperties(orderPageInfo, dtoPageInfo); return dtoPageInfo; } }
以上就是本文的全部?jī)?nèi)容,希望對(duì)大家的學(xué)習(xí)有所幫助,也希望大家多多支持創(chuàng)新互聯(lián)。