本文實(shí)例為大家分享了mybatis分頁插件使用的具體代碼,供大家參考,具體內(nèi)容如下
1.分頁插件簡介
都說這是史上最好用的分頁插件,支持多種數(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