Mybatis-Plus支持GBase8s分页查询的实现示例
作者:热心网友小红
MyBatis-Plus (简称 MP)是一个 MyBatis 的增强工具,在 MyBatis 的基础上只做增强不做改变,为简化开发、提高效率而生。在最新版 MP 中,已明确支持 南大通用数据库 (GBase 8s)。但是在分页查询上,绑定参数顺序不正确,需要一定调整。
使用的版本为:
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>
实现方法
确认拦截器类型,DbType选择对应枚举值。
@Configuration public class MyBatisPlusConfig { @Bean public MybatisPlusInterceptor mybatisPlusInterceptor() { MybatisPlusInterceptor interceptor = new MybatisPlusInterceptor(); //添加分页插件 interceptor.addInnerInterceptor(new PaginationInnerInterceptor(DbType.GBASEDBT)); return interceptor; } }
查看GBase8s对应枚举值,可参考路径 com.baomidou.mybatisplus.annotation.DbType
改写拦截器
可参考路径 com.baomidou.mybatisplus.extension.plugins.inner.PaginationInnerInterceptor ,随版本可能变化,可 调试 步入 定位拦截器位置。
如下为需要修改的代码段
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
找到对应目录下,会发现maven下载了 jar包 、源码、doc等相关内容,我们需要反编译 jar包内的 PaginationInnerInterceptor
改写源码,建议备份一份原始版本
复制出 mybatis-plus-extension-3.5.1.jar 包,解压缩,并找到 PaginationInnerInterceptor,反编译出来。
直接拖进IDEA就可以反编译了。
新建一个任意空工程,如图所示,创建包路径,类名全部与源码一致,并复制 反编译内容到新创建的 PaginationInnerInterceptor 类内。
接下来,需要将所有校验错误全部修正。
import相关错误,对应导入jar即可。
方法一,本地maven库下找到相关jar包,一个一个导入。
方法二,配置 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>
方法重写相关问题,添加注解 @Override 。
变量反编译相关问题,反编译会有一些小错误,如重复声明,对应修改即可;传参null注明类型的相关错误,直接删掉 如(Object)即可。
修改为
确定无校验错误后,修改源码,找到方法 beforeQuery,添加如下内容在对应位置。
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); }
编译工程,并找到对应 class 文件位置。
使用压缩程序直接打开本地maven库下的 mybatis-plus-extension-3.5.1.jar ,找到对应位置,直接替换 class
打开项目工程,reload maven库,直接运行,测试通过
到此这篇关于使 Mybatis-Plus 支持 GBase8s 的分页查询的文章就介绍到这了,更多相关Mybatis-Plus GBase8s分页查询内容请搜索脚本之家以前的文章或继续浏览下面的相关文章希望大家以后多多支持脚本之家!