Mybatis-plus支持Gbase8s分頁的實(shí)現(xiàn)示例
需求
實(shí)現(xiàn)mybatis-plus對(duì)gbase8s的分頁效果支持,使切換數(shù)據(jù)庫(如oracle/mysql/gbase8s)時(shí)同樣分頁插件代碼一樣實(shí)現(xiàn)分頁效果。
mybatis-plus版本:3.3.2
實(shí)現(xiàn)方法
修改Mybatis-plus源代碼,重新打jar包,引用其作為項(xiàng)目依賴。
尷尬的是,mybatis-plus源碼是gradle項(xiàng)目,目前沒學(xué)習(xí)過,結(jié)果改好了源碼不會(huì)打包…
在項(xiàng)目中重寫同包同類名的要修改的mybatis-plus源碼中的類,在項(xiàng)目啟動(dòng)中,會(huì)優(yōu)先加載項(xiàng)目里的代碼而不是jar包里的(適合本地,只覆蓋,不改變源代碼)
在項(xiàng)目中重寫同包同類名的要修改的mybatis-plus源碼中的類,編譯后替換解壓的源代碼中的class文件,再重新打回jar包(適合本地/Linux服務(wù)器,修改了源代碼jar包)
因?yàn)闀何唇佑|gradle打包,所以本文介紹了方法2、方法3
法2實(shí)現(xiàn)
因?yàn)橐貙戭?,所以記得引入原mybatis-plus的jar包依賴
目錄如圖

修改JdbcUtils,在url判斷中增加gbase8s判斷
else if (jdbcUrl.contains(":gbasedbt-sqli:")){
return DbType.GBASE8S;
}

在DbType類中增加對(duì)應(yīng)值
/**
* GBase8s
*/
GBASE8S("gbase8s", "南大通用數(shù)據(jù)庫"),

新增一個(gè)方言實(shí)現(xiàn)類GBase8sDialect
public class GBase8sDialect implements IDialect {
@Override
public DialectModel buildPaginationSql(String originalSql, long offset, long limit) {
Integer index = originalSql.toLowerCase().indexOf("select");
StringBuilder sql = new StringBuilder(originalSql);
sql.insert(index+6," skip " + FIRST_MARK + " first " + SECOND_MARK + " ");
return new DialectModel(sql.toString(), offset, limit).setConsumerChain();
}
}
在DialectRegistry中增加
dialect_enum_map.put(DbType.GBASE8S, new GBase8sDialect());

合計(jì)需要修改的類有JdbcUtils、DialectRegistry、DbType,同時(shí)新增一個(gè)方言類GBase8sDialect。
20210423 修改完善
上述情況有一個(gè)小bug:就是當(dāng)該分頁查詢有多于2個(gè)參數(shù)(即不止分頁參數(shù))時(shí),因?yàn)閙p默認(rèn)分頁參數(shù)動(dòng)態(tài)SQL參數(shù)匹配時(shí)在最后面,而Gbase8s的分頁參數(shù)是最前面兩個(gè),所以出現(xiàn)參數(shù)位置匹配不正確的問題!當(dāng)然,如果僅有兩個(gè)分頁參數(shù)則不影響
解決方案如下:
- 具體解決措施:重寫攔截器類PaginationInterceptor(com.baomidou.mybatisplus.extension.plugins),因?yàn)闆]搞懂其參數(shù)添加源碼,所以直接用了個(gè)笨辦法,修改參數(shù)位置
- 在intercept方法中把參數(shù)List中最后兩個(gè)參數(shù)放置到最前面:在model.consumers(mappings, configuration, additionalParameters);后加以下代碼(大約在213行)
mappings.add(0,mappings.get(mappings.size()-2)); mappings.add(0,mappings.get(mappings.size()-1)); mappings.remove(mappings.size()-1); mappings.remove(mappings.size()-1);
20210519完善
之前的情況完全適用于Gbase8s,但如果考慮多數(shù)據(jù)庫情況下,例切換到Oracle,會(huì)因?yàn)樽詈髢蓚€(gè)參數(shù)位置改變導(dǎo)致參數(shù)有誤,所以再次完善,把之前0423增加的代碼改為如下:
if(dbType.equals(DbType.GBASE8S)){
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);
}
20210528完善
之前的代碼在IDEA等本地開發(fā)環(huán)境上可以使用成功,但是當(dāng)部署在Linux服務(wù)器上時(shí),可能還是直接引用了mybatis-plus源代碼,沒有使用到編譯后的覆蓋內(nèi)容,導(dǎo)致不支持gbase8s.完善內(nèi)容原理如下:
- 正常使用maven打包工具,項(xiàng)目打包后會(huì)有之前加入的覆蓋代碼編譯后的各種class文件
- 把mybatis-plus(以下簡稱mp)的原jar包解壓(實(shí)際上只有兩個(gè)要改:mybatis-plus-extension-3.3.2.jar和mybatis-plus-annotation-3.3.2.jar),然后把第一步中編譯的覆蓋內(nèi)容class文件覆蓋到解壓后的源代碼同路徑下(重復(fù)的替換,新增的增加)
- 把替換后的源代碼重新打成jar包
- //進(jìn)入到源代碼目錄下,打開命令窗口,使用命令
jar cvf xxx.jar *,會(huì)在當(dāng)前目錄下生成新的xxxjar包 - 例:重新打mybatis-plus-extension-3.3.2.jar包
- 進(jìn)入解壓后的mybatis-plus-extension-3.3.2目錄(該目錄下有com和META-INF文件夾),cmd打開命令窗口(路徑為當(dāng)前目錄路徑),使用命令
jar cvf mybatis-plus-extension-3.3.2.jar *,會(huì)在當(dāng)前目錄下生成一個(gè)mybatis-plus-extension-3.3.2.jar包,把這個(gè)jar包替換maven庫中的同名jar包即可!另一個(gè)jar包同理
- //進(jìn)入到源代碼目錄下,打開命令窗口,使用命令
- 因?yàn)橹苯犹鎿Q了源代碼jar包,所以可以直接引用,同時(shí)可以把之前再項(xiàng)目例加的覆蓋內(nèi)容去了
到此這篇關(guān)于Mybatis-plus支持Gbase8s分頁的實(shí)現(xiàn)示例的文章就介紹到這了,更多相關(guān)Mybatis-plus Gbase8s分頁 內(nèi)容請(qǐng)搜索腳本之家以前的文章或繼續(xù)瀏覽下面的相關(guān)文章希望大家以后多多支持腳本之家!
相關(guān)文章
Shiro與Springboot整合開發(fā)的基本步驟過程詳解
這篇文章主要介紹了Shiro與Springboot整合開發(fā)的基本步驟,本文結(jié)合實(shí)例代碼給大家介紹整合過程,感興趣的朋友跟隨小編一起看看吧2023-06-06
一文搞懂接口參數(shù)簽名與驗(yàn)簽(附含java python php版)
這篇文章主要為大家介紹了java python php不同版的接口參數(shù)簽名與驗(yàn)簽示例詳解,有需要的朋友可以借鑒參考下,希望能夠有所幫助,祝大家多多進(jìn)步,早日升職加薪2023-06-06
Springboot 整合通用mapper和pagehelper展示分頁數(shù)據(jù)的問題(附github源碼)
這篇文章主要介紹了Springboot 整合通用mapper和pagehelper展示分頁數(shù)據(jù)(附github源碼),本文通過實(shí)例代碼給大家介紹的非常詳細(xì),對(duì)大家的學(xué)習(xí)或工作具有一定的參考借鑒價(jià)值,需要的朋友可以參考下2021-09-09
Java常見問題之javac Hello.java找不到文件的解決方法
剛開始編寫java代碼時(shí),肯定會(huì)遇到各種各樣的bug,當(dāng)然對(duì)于初學(xué)者這也是能理解的,下面這篇文章主要給大家介紹了關(guān)于Java常見問題之javac Hello.java找不到文件解決的相關(guān)資料,文中通過圖文介紹的非常詳細(xì),需要的朋友可以參考下。2018-01-01
MyBatis實(shí)現(xiàn)萬能Map和模糊查詢
本文主要介紹了MyBatis實(shí)現(xiàn)萬能Map和模糊查詢,文中通過示例代碼介紹的非常詳細(xì),需要的朋友們下面隨著小編來一起學(xué)習(xí)學(xué)習(xí)吧2021-07-07
eclipse中自動(dòng)生成構(gòu)造函數(shù)的兩種方法
下面小編就為大家?guī)硪黄猠clipse中自動(dòng)生成構(gòu)造函數(shù)的兩種方法。小編覺得挺不錯(cuò)的,現(xiàn)在就分享給大家,也給大家做個(gè)參考。一起跟隨小編過來看看吧2017-10-10
springboot通過SchedulingConfigurer實(shí)現(xiàn)多定時(shí)任務(wù)注冊及動(dòng)態(tài)修改執(zhí)行周期(示例詳解)
這篇文章主要介紹了springboot通過SchedulingConfigurer實(shí)現(xiàn)多定時(shí)任務(wù)注冊及動(dòng)態(tài)修改執(zhí)行周期,本文通過實(shí)例代碼給大家介紹的非常詳細(xì),對(duì)大家的學(xué)習(xí)或工作具有一定的參考借鑒價(jià)值,需要的朋友可以參考下2023-06-06

