Mybatis-Plus支持GBase8s分頁查詢的實現(xiàn)示例
MyBatis-Plus (簡稱 MP)是一個 MyBatis 的增強工具,在 MyBatis 的基礎(chǔ)上只做增強不做改變,為簡化開發(fā)、提高效率而生。在最新版 MP 中,已明確支持 南大通用數(shù)據(jù)庫 (GBase 8s)。但是在分頁查詢上,綁定參數(shù)順序不正確,需要一定調(diào)整。
使用的版本為:
mybatis-plus版本:3.5.1
使用 maven 管理依賴。
<!--mybatis_plus-->
<dependency>
<groupId>com.baomidou</groupId>
<artifactId>mybatis-plus-boot-starter</artifactId>
<version>3.5.1</version>
</dependency>
實現(xiàn)方法
確認攔截器類型,DbType選擇對應(yīng)枚舉值。
@Configuration
public class MyBatisPlusConfig {
@Bean
public MybatisPlusInterceptor mybatisPlusInterceptor() {
MybatisPlusInterceptor interceptor = new MybatisPlusInterceptor();
//添加分頁插件
interceptor.addInnerInterceptor(new PaginationInnerInterceptor(DbType.GBASEDBT));
return interceptor;
}
}
查看GBase8s對應(yīng)枚舉值,可參考路徑 com.baomidou.mybatisplus.annotation.DbType

改寫攔截器
可參考路徑 com.baomidou.mybatisplus.extension.plugins.inner.PaginationInnerInterceptor ,隨版本可能變化,可 調(diào)試 步入 定位攔截器位置。
如下為需要修改的代碼段
IDialect dialect = this.findIDialect(executor);
Configuration configuration = ms.getConfiguration();
DialectModel model = dialect.buildPaginationSql(buildSql, page.offset(), page.getSize());
MPBoundSql mpBoundSql = PluginUtils.mpBoundSql(boundSql);
List<ParameterMapping> mappings = mpBoundSql.parameterMappings();
Map<String, Object> additionalParameter = mpBoundSql.additionalParameters();
model.consumers(mappings, configuration, additionalParameter);
mpBoundSql.sql(model.getDialectSql());
mpBoundSql.parameterMappings(mappings);
找到本地依賴包位置, com.baomidou.mybatisplus.extension

找到對應(yīng)目錄下,會發(fā)現(xiàn)maven下載了 jar包 、源碼、doc等相關(guān)內(nèi)容,我們需要反編譯 jar包內(nèi)的 PaginationInnerInterceptor
改寫源碼,建議備份一份原始版本

復(fù)制出 mybatis-plus-extension-3.5.1.jar 包,解壓縮,并找到 PaginationInnerInterceptor,反編譯出來。
直接拖進IDEA就可以反編譯了。


新建一個任意空工程,如圖所示,創(chuàng)建包路徑,類名全部與源碼一致,并復(fù)制 反編譯內(nèi)容到新創(chuàng)建的 PaginationInnerInterceptor 類內(nèi)。

接下來,需要將所有校驗錯誤全部修正。
import相關(guān)錯誤,對應(yīng)導(dǎo)入jar即可。

方法一,本地maven庫下找到相關(guān)jar包,一個一個導(dǎo)入。

方法二,配置 maven下載,在 pom.xml中添加
<!--mybatis_plus-->
<dependency>
<groupId>com.baomidou</groupId>
<artifactId>mybatis-plus-boot-starter</artifactId>
<version>3.5.1</version>
</dependency>
<!-- lombok 依賴 -->
<dependency>
<groupId>org.projectlombok</groupId>
<artifactId>lombok</artifactId>
<version>1.16.10</version>
</dependency>
方法重寫相關(guān)問題,添加注解 @Override 。

變量反編譯相關(guān)問題,反編譯會有一些小錯誤,如重復(fù)聲明,對應(yīng)修改即可;傳參null注明類型的相關(guān)錯誤,直接刪掉 如(Object)即可。

修改為

確定無校驗錯誤后,修改源碼,找到方法 beforeQuery,添加如下內(nèi)容在對應(yīng)位置。
if(dbType.equals(DbType.GBASEDBT)){
mappings.add(0,mappings.get(mappings.size()-1));
mappings.add(0,mappings.get(mappings.size()-2));
mappings.remove(mappings.size()-1);
mappings.remove(mappings.size()-1);
}

編譯工程,并找到對應(yīng) class 文件位置。


使用壓縮程序直接打開本地maven庫下的 mybatis-plus-extension-3.5.1.jar ,找到對應(yīng)位置,直接替換 class

打開項目工程,reload maven庫,直接運行,測試通過

到此這篇關(guān)于使 Mybatis-Plus 支持 GBase8s 的分頁查詢的文章就介紹到這了,更多相關(guān)Mybatis-Plus GBase8s分頁查詢內(nèi)容請搜索腳本之家以前的文章或繼續(xù)瀏覽下面的相關(guān)文章希望大家以后多多支持腳本之家!
- mybatis-plus分頁查詢?nèi)N方法小結(jié)
- Mybatis-plus分頁查詢不生效問題排查全過程
- Mybatis-plus的selectPage()分頁查詢不生效問題解決
- mybatis-plus實現(xiàn)自定義SQL、多表查詢與多表分頁查詢語句實例
- Mybatis-Plus或PageHelper多表分頁查詢總條數(shù)不對問題的解決方法
- 如何使用mybatis-plus實現(xiàn)分頁查詢功能
- 一文搞懂Mybatis-plus的分頁查詢操作
- MyBatis-Plus?分頁查詢的實現(xiàn)示例
- mybatis-plus分頁查詢的實現(xiàn)示例
- MyBatis-Plus 分頁查詢以及自定義sql分頁的實現(xiàn)
相關(guān)文章
Maven dependencies與dependencyManagement的區(qū)別詳解
這篇文章主要介紹了Maven dependencies與dependencyManagement的區(qū)別詳解,小編覺得挺不錯的,現(xiàn)在分享給大家,也給大家做個參考。一起跟隨小編過來看看吧2019-04-04
Java通過httpclient比較重定向和請求轉(zhuǎn)發(fā)
這篇文章主要介紹了Java通過httpclient比較重定向和請求轉(zhuǎn)發(fā),HttpClient?4.x?版本,get請求方法會自動進行重定向,而post請求方法不會自動進行重定向,需要的朋友可以參考下2023-04-04
SpringMVC @RequestMapping注解應(yīng)用方法示例講解
通過@RequestMapping注解可以定義不同的處理器映射規(guī)則,下面這篇文章主要給大家介紹了關(guān)于SpringMVC中@RequestMapping注解用法的相關(guān)資料,文中通過實例代碼介紹的非常詳細,需要的朋友可以參考下2022-09-09
Java二叉搜索樹基礎(chǔ)原理與實現(xiàn)方法詳解
這篇文章主要介紹了Java二叉搜索樹基礎(chǔ)原理與實現(xiàn)方法,結(jié)合圖文與實例形式詳細分析了Java二叉搜索樹的基本概念、原理、實現(xiàn)方法與操作注意事項,需要的朋友可以參考下2020-03-03

