Mybatis-plus支持Gbase8s分页的实现示例
需求
实现mybatis-plus对gbase8s的分页效果支持,使切换数据库(如oracle/mysql/gbase8s)时同样分页插件代码一样实现分页效果。
mybatis-plus版本:3.3.2
实现方法
修改Mybatis-plus源代码,重新打jar包,引用其作为项目依赖。
尴尬的是,mybatis-plus源码是gradle项目,目前没学习过,结果改好了源码不会打包…
在项目中重写同包同类名的要修改的mybatis-plus源码中的类,在项目启动中,会优先加载项目里的代码而不是jar包里的(适合本地,只覆盖,不改变源代码)
在项目中重写同包同类名的要修改的mybatis-plus源码中的类,编译后替换解压的源代码中的class文件,再重新打回jar包(适合本地/Linux服务器,修改了源代码jar包)
因为暂未接触gradle打包,所以本文介绍了方法2、方法3
法2实现
因为要重写类,所以记得引入原mybatis-plus的jar包依赖
目录如图
修改JdbcUtils,在url判断中增加gbase8s判断
else if (jdbcUrl.contains(":gbasedbt-sqli:")){ return DbType.GBASE8S; }
在DbType类中增加对应值
/** * GBase8s */ GBASE8S("gbase8s", "南大通用数据库"),
新增一个方言实现类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());
合计需要修改的类有JdbcUtils、DialectRegistry、DbType,同时新增一个方言类GBase8sDialect。
20210423 修改完善
上述情况有一个小bug:就是当该分页查询有多于2个参数(即不止分页参数)时,因为mp默认分页参数动态SQL参数匹配时在最后面,而Gbase8s的分页参数是最前面两个,所以出现参数位置匹配不正确的问题!当然,如果仅有两个分页参数则不影响
解决方案如下:
- 具体解决措施:重写拦截器类PaginationInterceptor(com.baomidou.mybatisplus.extension.plugins),因为没搞懂其参数添加源码,所以直接用了个笨办法,修改参数位置
- 在intercept方法中把参数List中最后两个参数放置到最前面:在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,但如果考虑多数据库情况下,例切换到Oracle,会因为最后两个参数位置改变导致参数有误,所以再次完善,把之前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等本地开发环境上可以使用成功,但是当部署在Linux服务器上时,可能还是直接引用了mybatis-plus源代码,没有使用到编译后的覆盖内容,导致不支持gbase8s.完善内容原理如下:
- 正常使用maven打包工具,项目打包后会有之前加入的覆盖代码编译后的各种class文件
- 把mybatis-plus(以下简称mp)的原jar包解压(实际上只有两个要改:mybatis-plus-extension-3.3.2.jar和mybatis-plus-annotation-3.3.2.jar),然后把第一步中编译的覆盖内容class文件覆盖到解压后的源代码同路径下(重复的替换,新增的增加)
- 把替换后的源代码重新打成jar包
- //进入到源代码目录下,打开命令窗口,使用命令
jar cvf xxx.jar *
,会在当前目录下生成新的xxxjar包 - 例:重新打mybatis-plus-extension-3.3.2.jar包
- 进入解压后的mybatis-plus-extension-3.3.2目录(该目录下有com和META-INF文件夹),cmd打开命令窗口(路径为当前目录路径),使用命令
jar cvf mybatis-plus-extension-3.3.2.jar *
,会在当前目录下生成一个mybatis-plus-extension-3.3.2.jar包,把这个jar包替换maven库中的同名jar包即可!另一个jar包同理
- //进入到源代码目录下,打开命令窗口,使用命令
- 因为直接替换了源代码jar包,所以可以直接引用,同时可以把之前再项目例加的覆盖内容去了
栏 目:JAVA代码
下一篇:在js与java中判断json数据中是否含有某字段的案例
本文标题:Mybatis-plus支持Gbase8s分页的实现示例
本文地址:http://www.codeinn.net/misctech/226818.html