一区二区三区在线-一区二区三区亚洲视频-一区二区三区亚洲-一区二区三区午夜-一区二区三区四区在线视频-一区二区三区四区在线免费观看

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

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

總結

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

延伸 · 閱讀

精彩推薦
主站蜘蛛池模板: s8sp加密路线和免费路线首页 | 精品国产美女福利在线 | 国产51 | 东京干福利 | 免费一级日本c片完整版 | 香蕉在线精品一区二区 | 亚洲经典激情春色另类 | www.色姐姐| 国产精品福利短视在线播放频 | 办公室里被迫高h | 我的青梅竹马是消防员2季未增删免费 | 国产图色 | 暖暖视频高清图片免费完整版 | 午夜久久久久久亚洲国产精品 | 四虎影视国产精品婷婷 | 欧美特欧美特级一片 | 色图图片 | 日韩视频免费一区二区三区 | 亚洲同性男男gay1069 | 国产精品免费精品自在线观看 | 深夜精品高中女学生 | 美女私人影院 | 日本孕妇大胆孕交 | 嫩草影院永久入口在线观看 | 欧美性高清另类videosex死尸 | 性色AV乱码一区二区三区视频 | 99久久精品免费精品国产 | 日韩欧美一区二区三区中文精品 | 99精品视频在线观看 | 国产成人精品免费视频大全五级 | 国产欧美日韩专区 | 国产日韩欧美综合一区二区三区 | 色在线亚洲视频www 色欲麻豆国产福利精品 | 日本无翼乌漫画 | 欧美最新在线 | 国产精品一区二区久久 | 国产真实一区二区三区 | 色欲都市| 91免费永久国产在线观看 | 国产精品视频一区二区三区w | tube69中国露脸 |