亚洲香蕉成人av网站在线观看_欧美精品成人91久久久久久久_久久久久久久久久久亚洲_热久久视久久精品18亚洲精品_国产精自产拍久久久久久_亚洲色图国产精品_91精品国产网站_中文字幕欧美日韩精品_国产精品久久久久久亚洲调教_国产精品久久一区_性夜试看影院91社区_97在线观看视频国产_68精品久久久久久欧美_欧美精品在线观看_国产精品一区二区久久精品_欧美老女人bb

首頁 > 開發 > Java > 正文

Mybatis分頁插件使用方法詳解

2024-07-14 08:43:24
字體:
來源:轉載
供稿:網友

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

以上就是本文的全部內容,希望對大家的學習有所幫助,也希望大家多多支持VeVb武林網。


注:相關教程知識閱讀請移步到JAVA教程頻道。
發表評論 共有條評論
用戶名: 密碼:
驗證碼: 匿名發表
亚洲香蕉成人av网站在线观看_欧美精品成人91久久久久久久_久久久久久久久久久亚洲_热久久视久久精品18亚洲精品_国产精自产拍久久久久久_亚洲色图国产精品_91精品国产网站_中文字幕欧美日韩精品_国产精品久久久久久亚洲调教_国产精品久久一区_性夜试看影院91社区_97在线观看视频国产_68精品久久久久久欧美_欧美精品在线观看_国产精品一区二区久久精品_欧美老女人bb
久久久国产精彩视频美女艺术照福利| 精品欧美一区二区三区| 日韩午夜在线视频| 在线精品播放av| 国产亚洲欧洲高清一区| 国产欧美日韩免费看aⅴ视频| 日韩精品欧美国产精品忘忧草| 欧美精品成人91久久久久久久| 美女精品久久久| 欧美裸体xxxx极品少妇| 成人亚洲激情网| 91精品在线观看视频| 久久精品视频中文字幕| 国产热re99久久6国产精品| 久久久成人精品视频| 日韩av免费看网站| 日韩视频免费大全中文字幕| 欧美激情精品久久久久久免费印度| 日韩精品视频中文在线观看| 欧美极品美女视频网站在线观看免费| 国产成人极品视频| 国产精品手机播放| 久久亚洲精品网站| 一区二区三区视频免费在线观看| 亚洲国产欧美精品| 亚洲黄色成人网| 国产精品久久久久久av| 亚洲区一区二区| 91精品国产自产在线观看永久| 欧美激情va永久在线播放| 日韩av中文在线| 久色乳综合思思在线视频| 国产精品一区二区久久国产| 91中文精品字幕在线视频| 亚洲一区二区三区毛片| 欧美疯狂做受xxxx高潮| 日韩美女写真福利在线观看| 亚洲a∨日韩av高清在线观看| 亚洲成人久久电影| 一本一本久久a久久精品牛牛影视| 88国产精品欧美一区二区三区| 欧美怡春院一区二区三区| 成人性生交xxxxx网站| 麻豆一区二区在线观看| 亚洲国产精品久久久久| 国产精品尤物福利片在线观看| 91久久国产综合久久91精品网站| 九九热精品视频国产| 久久不射热爱视频精品| 国产欧美一区二区三区在线看| 日韩精品极品毛片系列视频| 在线看日韩av| 精品久久久一区| 欧美成人国产va精品日本一级| 亚洲欧洲日产国产网站| 亚洲毛片一区二区| 色与欲影视天天看综合网| 97国产suv精品一区二区62| 一本色道久久88亚洲综合88| 秋霞成人午夜鲁丝一区二区三区| 狠狠色狠色综合曰曰| 国产在线精品自拍| 中文字幕亚洲激情| 国产亚洲人成网站在线观看| 欧美色道久久88综合亚洲精品| 日韩av综合中文字幕| 98精品在线视频| 国产精品视频网| 欧美精品aaa| 伊人成人开心激情综合网| 亚洲男女自偷自拍图片另类| 91九色单男在线观看| 亚洲天堂免费观看| 色在人av网站天堂精品| 8x海外华人永久免费日韩内陆视频| 免费91麻豆精品国产自产在线观看| 欧美黑人xxxⅹ高潮交| 欧美另类第一页| 这里只有精品在线播放| 久久精视频免费在线久久完整在线看| 福利微拍一区二区| 不卡av日日日| 日韩在线欧美在线| 国产主播欧美精品| 国产精品白丝jk喷水视频一区| 日韩国产一区三区| 亚洲成人1234| 国产精品日韩精品| 久久成人综合视频| 国产精品久久久久久久9999| 91欧美视频网站| 久热精品在线视频| 韩国精品美女www爽爽爽视频| 亚洲片av在线| 久久精品国产99国产精品澳门| 国产精品激情av电影在线观看| 欧美丰满少妇xxxxx做受| 日韩欧美视频一区二区三区| 91极品女神在线| 国产日韩精品在线| 日本精品久久中文字幕佐佐木| 久久伊人免费视频| 萌白酱国产一区二区| 日韩免费在线视频| 日韩av一区二区在线观看| 国内精品久久久久影院 日本资源| 91九色综合久久| 日本欧美一二三区| 日韩精品免费在线观看| 亚洲福利精品在线| 第一福利永久视频精品| 自拍偷拍免费精品| 一本大道久久加勒比香蕉| 爱福利视频一区| 在线成人激情视频| 亚洲人精选亚洲人成在线| 国产成人免费av| 亚洲美女喷白浆| 日韩中文字幕不卡视频| 97精品伊人久久久大香线蕉| 欧美激情一区二区三区高清视频| 亚洲人成电影在线播放| 欧美一区二区色| 日韩在线视频中文字幕| 欧美电影在线观看| 久久精品精品电影网| 26uuu久久噜噜噜噜| 在线电影欧美日韩一区二区私密| 久久国产一区二区三区| www.美女亚洲精品| 欧美电影免费观看电视剧大全| 久久久久久久久久久免费| 中文字幕亚洲第一| 久久久久久999| 欧美日韩一区二区免费视频| 国产精品自拍视频| 一区二区三区精品99久久| 欧美在线视频网| 国产精品一区二区电影| 亚洲精品电影在线观看| 亚洲精品在线看| 国产成人aa精品一区在线播放| 久久久久久久久国产精品| 亚洲精品免费一区二区三区| 欧美激情国产高清| 久久在线免费视频| 精品欧美国产一区二区三区| 亚洲精品自产拍| 国产精品久久久久久久久久尿| 亚洲欧美日韩久久久久久| yellow中文字幕久久| 一个人看的www久久| 国产成一区二区| 中文字幕不卡在线视频极品| 欧美色视频日本高清在线观看| 红桃av永久久久| 国产精品午夜一区二区欲梦| 97超碰国产精品女人人人爽| 欧美成人在线网站| 国产日韩欧美在线视频观看| 成人观看高清在线观看免费| 97在线免费视频| 成人情趣片在线观看免费| 欧美国产日韩免费|