激情久久久_欧美视频区_成人av免费_不卡视频一二三区_欧美精品在欧美一区二区少妇_欧美一区二区三区的

服務(wù)器之家:專注于服務(wù)器技術(shù)及軟件下載分享
分類導(dǎo)航

PHP教程|ASP.NET教程|Java教程|ASP教程|編程技術(shù)|正則表達(dá)式|C/C++|IOS|C#|Swift|Android|VB|R語言|JavaScript|易語言|vb.net|

香港云服务器
服務(wù)器之家 - 編程語言 - Java教程 - Mybatis分頁插件使用方法詳解

Mybatis分頁插件使用方法詳解

2021-06-26 13:25Javxuan Java教程

這篇文章主要為大家詳細(xì)介紹了Mybatis分頁插件的使用方法,具有一定的參考價(jià)值,感興趣的小伙伴們可以參考一下

本文實(shí)例為大家分享了mybatis分頁插件使用的具體代碼,供大家參考,具體內(nèi)容如下

1.分頁插件簡介

pagehelper源碼

都說這是史上最好用的分頁插件,支持多種數(shù)據(jù)庫以多種方式分頁。

2.分頁插件的使用

2.1導(dǎo)入maven依賴

?
1
2
3
4
5
<dependency>
 <groupid>com.github.pagehelper</groupid>
 <artifactid>pagehelper</artifactid>
 <version>最新版本</version>
</dependency>

2.2 添加配置

1.在mybatis的config配置文件中添加攔截器 <plugin>

?
1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
21
22
23
24
25
26
27
28
29
30
31
32
<!--
 plugins在配置文件中的位置必須符合要求,否則會報(bào)錯,順序如下:
 properties?, settings?,
 typealiases?, typehandlers?,
 objectfactory?,objectwrapperfactory?,
 plugins?,
 environments?, databaseidprovider?, mappers?
-->
<plugins>
  <plugin interceptor="com.github.pagehelper.pagehelper">
   <property name="dialect" value="mysql"/>
   <!-- 該參數(shù)默認(rèn)為false -->
   <!-- 設(shè)置為true時(shí),會將rowbounds第一個參數(shù)offset當(dāng)成pagenum頁碼使用 -->
   <!-- 和startpage中的pagenum效果一樣-->
   <property name="offsetaspagenum" value="true"/>
   <!-- 該參數(shù)默認(rèn)為false -->
   <!-- 設(shè)置為true時(shí),使用rowbounds分頁會進(jìn)行count查詢 -->
   <property name="rowboundswithcount" value="true"/>
   <!-- 設(shè)置為true時(shí),如果pagesize=0或者rowbounds.limit = 0就會查詢出全部的結(jié)果 -->
   <!-- (相當(dāng)于沒有執(zhí)行分頁查詢,但是返回結(jié)果仍然是page類型)-->
   <property name="pagesizezero" value="true"/>
   <!-- 3.3.0版本可用 - 分頁參數(shù)合理化,默認(rèn)false禁用 -->
   <!-- 啟用合理化時(shí),如果pagenum<1會查詢第一頁,如果pagenum>pages會查詢最后一頁 -->
   <!-- 禁用合理化時(shí),如果pagenum<1或pagenum>pages會返回空數(shù)據(jù) -->
   <property name="reasonable" value="false"/>
   <!-- 3.5.0版本可用 - 為了支持startpage(object params)方法 -->
   <!-- 增加了一個`params`參數(shù)來配置參數(shù)映射,用于從map或servletrequest中取值 -->
   <!-- 可以配置pagenum,pagesize,count,pagesizezero,reasonable,不配置映射的用默認(rèn)值 -->
   <!-- 不理解該含義的前提下,不要隨便復(fù)制該配置 -->
   <property name="params" value="pagenum=start;pagesize=limit;"/>
  </plugin>
</plugins>

2.或者在spring配置中添加

?
1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
<bean id="sqlsessionfactory" class="org.mybatis.spring.sqlsessionfactorybean">
 <!-- 注意其他配置 -->
 <property name="plugins">
 <array>
  <bean class="com.github.pagehelper.pageinterceptor">
  <property name="properties">
   <!--使用下面的方式配置參數(shù),一行配置一個 -->
   <value>
   params=value1
   </value>
  </property>
  </bean>
 </array>
 </property>
</bean>

這兩種方式不能同時(shí)用

3.在代碼中的使用

3.1設(shè)置一個基礎(chǔ)的請求類

?
1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
21
22
23
24
25
26
27
28
29
30
31
32
33
34
35
36
37
38
39
40
public class baserequest implements serializable {
 
 private static final long serialversionuid = 1193444819529643410l;
 
 private integer pagenum;//頁數(shù)
 private integer pagesize;//每頁行數(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è)置一個基礎(chǔ)的pageservice 接口

讓每個service 去實(shí)現(xiàn)這個接口來設(shè)置分頁的初始值

?
1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
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)換這用來復(fù)制屬性值(可選)

數(shù)據(jù)模型entity 只對應(yīng)數(shù)據(jù)庫表中的字段, 出參與入?yún)?都是數(shù)據(jù)傳輸對象 dto , 從數(shù)據(jù)庫中查出來的是entity而 接口返回的是dto 所要beanutils.copyproperties復(fù)制屬性,和pageutils.copyproperties 復(fù)制分頁屬性

?
1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
21
22
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)類中

?
1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
21
22
23
24
25
26
27
28
29
30
31
32
33
34
35
36
37
38
39
40
41
42
43
44
45
46
47
48
49
50
51
52
53
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){
  //設(shè)置默認(rèn)分頁信息 pageservice的方法
  setdefaultpageinfo(orderrequest);
 
  //查出order列表
  list<order> orderlist = ordermapper.selectlist();
  //將entity的列表分頁
  pageinfo<order> orderpageinfo = new pageinfo<>(orderlist);
 
  //連續(xù)顯示5頁與上面的二選一
  //pageinfo<order> orderpageinfo = new pageinfo<>(orderlist,5);
 
  //定義一個數(shù)據(jù)傳輸對象dtolist
  list<orderdto> 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 分頁
  pageinfo<orderdto> dtopageinfo = new pageinfo<>(dtolist);
 
  //連續(xù)顯示5頁 與上面的二選一
  //pageinfo<order> orderpageinfo = new pageinfo<>(orderlist,5);
 
  //將entity的分頁信息復(fù)制給dtopageinfo上
  pageutils.copyproperties(orderpageinfo, dtopageinfo);
  return dtopageinfo;
 }
}

以上就是本文的全部內(nèi)容,希望對大家的學(xué)習(xí)有所幫助,也希望大家多多支持服務(wù)器之家。

原文鏈接:https://blog.csdn.net/u014297148/article/details/80444454

延伸 · 閱讀

精彩推薦
743
主站蜘蛛池模板: 夜间福利网站 | 成年人福利视频 | 欧美在线综合视频 | 中国女警察一级毛片视频 | 粉嫩一区 | 国产一级毛片在线看 | 亚洲国产视频在线 | 免费久久久 | 国产一区二区三区四 | 久久9999久久 | 日韩视频在线一区二区三区 | 国产视频软件在线 | 欧美精品一区二区三区久久久 | 欧美一级片免费在线观看 | 视频在线91 | 午夜天堂在线视频 | 久草在线播放视频 | 国产精品色综合 | 久草在线视频免费播放 | 亚洲天堂字幕 | 国产精品久久久久久久久久久久久久久 | 午夜生活理论片 | 国产精选久久久 | 少妇一级淫片免费放正片 | 国产91成人| 色视频欧美 | 91精品一区二区综合在线 | 欧美 日本 在线 | 日本精品视频一区二区三区四区 | 亚洲91网| 久操福利视频 | 黄色美女免费 | 99久久精品国产导航 | 国产亚洲精品久久久久久久久久 | 爱唯侦察 国产合集 亚洲 | 欧美精品38videos性欧美 | 午夜影院在线免费观看 | 亚洲卡通动漫在线观看 | www.成人精品 | 在线成人www免费观看视频 | 国产精品野外av久久久 |