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

服務器之家:專注于服務器技術及軟件下載分享
分類導航

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

服務器之家 - 編程語言 - Java教程 - mybatis攔截器與分頁插件實例教程

mybatis攔截器與分頁插件實例教程

2021-07-28 12:06五頭牛 Java教程

Mybatis攔截器常常會被用來進行分頁處理。所以下面這篇文章主要給大家介紹了關于mybatis攔截器與分頁插件的相關資料,文中通過示例代碼介紹的非常詳細,對大家學習或者使用mybatis具有一定的參考學習價值,需要的朋友們下面來

mybatis介紹

攔截器的一個作用就是我們可以攔截某些方法的調用,我們可以選擇在這些被攔截的方法執行前后加上某些邏輯,也可以在執行這些被攔截的方法時執行自己的邏輯而不再執行被攔截的方法。

mybatis 是一款優秀的持久層框架,它支持定制化 sql、存儲過程以及高級映射。mybatis 避免了幾乎所有的 jdbc 代碼和手動設置參數以及獲取結果集。mybatis 可以使用簡單的 xml 或注解來配置和映射原生類型、接口和 java 的 pojo(plain old java objects,普通老式 java 對象)為數據庫中的記錄。

mybatis架構圖

mybatis攔截器與分頁插件實例教程

我們這個demo實現就是基于mybatis的插件模塊(主要實現mybatis的interceptor接口)

interceptor接口

?
1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
package org.apache.ibatis.plugin;
 
import java.util.properties;
 
/**
 * @author clinton begin
 */
public interface interceptor {
 
 object intercept(invocation invocation) throws throwable;
 
 object plugin(object target);
 
 void setproperties(properties properties);
}

demo實現

主要技術 spring boot + mybatis

pom.xml

?
1
2
3
4
5
6
7
8
9
10
<dependency>
 <groupid>org.mybatis.spring.boot</groupid>
 <artifactid>mybatis-spring-boot-starter</artifactid>
 <version>1.3.2</version>
</dependency>
<dependency>
 <groupid>mysql</groupid>
 <artifactid>mysql-connector-java</artifactid>
 <scope>runtime</scope>
 </dependency>

數據庫 ddl

?
1
2
3
4
5
create table user
(
 id int  auto_increment primary key,
 username varchar(20) null
);

核心代碼

?
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
@override
public object intercept(invocation invocation) throws throwable {
logger.info("進入攔截器");
object[] args = invocation.getargs();
mappedstatement mappedstatement = (mappedstatement) args[0];
 
//獲取參數
object param = invocation.getargs()[1];
boundsql boundsql = mappedstatement.getboundsql(param);
object parameterobject = boundsql.getparameterobject();
 
/**
 * 判斷是否是繼承pagevo來判斷是否需要進行分頁
 */
if (parameterobject instanceof pagevo) {
 //強轉 為了拿到分頁數據
 pagevo pagevo = (pagevo) param;
 string sql = boundsql.getsql();
 
 //獲取相關配置
 configuration config = mappedstatement.getconfiguration();
 connection connection = config.getenvironment().getdatasource().getconnection();
 
 //拼接查詢當前條件的sql的總條數
 string countsql = "select count(*) from (" + sql + ") a";
 preparedstatement preparedstatement = connection.preparestatement(countsql);
 boundsql countboundsql = new boundsql(config, countsql, boundsql.getparametermappings(), boundsql.getparameterobject());
 parameterhandler parameterhandler = new defaultparameterhandler(mappedstatement, parameterobject, countboundsql);
 parameterhandler.setparameters(preparedstatement);
 //執行獲得總條數
 resultset rs = preparedstatement.executequery();
 int count = 0;
 if (rs.next()) {
 count = rs.getint(1);
 }
 //拼接分頁sql
 string pagesql = sql + " limit " + pagevo.getlimit() + " , " + pagevo.getoffset();
 //重新執行新的sql
 donewsql(invocation, pagesql);
 
 object result = invocation.proceed();
 connection.close();
 //處理新的結構
 pageresult<?> pageresult = new pageresult<list>(pagevo.page, pagevo.rows, count, (list) result);
 list<pageresult> returnresultlist = new arraylist<>();
 returnresultlist.add(pageresult);
 
 return returnresultlist;
}
return invocation.proceed();
}

測試結果

mybatis攔截器與分頁插件實例教程

github地址:https://github.com/xinyanjiang/mybaits-plugs

總結

以上就是這篇文章的全部內容了,希望本文的內容對大家的學習或者工作具有一定的參考學習價值,謝謝大家對服務器之家的支持。

延伸 · 閱讀

精彩推薦
主站蜘蛛池模板: 国产91亚洲精品久久久 | 91九色福利 | 欧美成人二区 | 黄色特级视频 | 91情侣在线偷精品国产 | 国产色妞影院wwwxxx | 91嫩草丨国产丨精品入口 | 男女羞羞视频 | 国产精品久久久久久久hd | 欧美a∨一区二区三区久久黄 | 亚洲99| 黄色片网页 | 特级a欧美做爰片毛片 | 久久精品视频黄色 | 国产午夜亚洲精品午夜鲁丝片 | 神马顶级推理片免费看 | 成人三级电影网址 | 国产精品自拍av | 狠狠操人人干 | 91精品国产综合久久久欧美 | 亚洲3p激情在线观看 | 亚洲成人国产综合 | 久久99精品久久久久久秒播放器 | 在线免费观看精品 | 成人激情视频网 | 亚洲影视在线 | 久久密| 成人在线免费小视频 | 国产精品免费av一区二区三区 | 精品99在线视频 | 国产自在自线午夜精品视频在 | 成年毛片| 国产成人精品一区二区仙踪林 | 国产污污视频 | 美国av免费看 | 成人在线免费观看小视频 | 99麻豆久久久国产精品免费 | 精品一区久久久 | 最近国产中文字幕 | 日韩在线视频观看免费 | 成人免费一区二区三区 |