Mybatis-Plus支持GBase8s分页查询的实现示例
作者:热心网友小红 发布时间:2021-11-21 14:33:30
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库,直接运行,测试通过
来源:https://blog.csdn.net/qq_33935229/article/details/127918613
猜你喜欢
- Apache Dubbo是一款高性能、轻量级的开源 Java RPC 框架,它提供了三大核心能力:面向接口的远程方法调用,智能容错和负载均衡
- 前言:最近终于用上了高性能的测试机(54C96G * 3),相较之前的单机性能提升了三倍,数量提升了三倍,更关键的宽带提单机升了30倍不止,
- Jackson反序列化遇到的问题最近在项目中需要使用Jackson把前台转来的字符转为对象,转换过程中发生了错误,报错如下com.faste
- 一.显示、隐藏 jQuery 中显示方法为:.show(),隐藏方法为:.hide()。在无参数的时候,只是硬性的显示内容和隐藏内
- 现如今打开一个 App,比如头条、微博,都会有长列表,随着我们不断地滑动,视窗内的内容也会不断地更新。今天就用 Flutter 实现一下这种
- 限流器算法目前常用限流器算法为两种:令牌桶算法和漏桶算法,主要区别在于:漏桶算法能够强行限制请求速率,平滑突发请求,而令牌桶算法在限定平均速
- 今天我们来讨论如何在项目开发中优雅地使用RocketMQ。本文分为三部分,第一部分实现SpringBoot与RocketMQ的整合,第二部分
- 1、volley 项目地址 https://github.com/smanikandan14/Volley-demo (1)&nb
- JACOB的方法,足可以解决这个问题,但是我既然以前曾经做过报表,就想尝试不同的方法。JACOB是一座连接JAVA和微软的桥,所有的解析由微
- 前言今天介绍的是关于Spring的数据库连接以及Jdbc模板的相关API方法,虽然在学习了hibernate之后,会知道实现数据库连接一般都
- 最近开发项目中,有个在屏幕上任意拖动的悬浮窗功能,其实就是利用 WindowManager的api来完成这个需求,具体的实现的功能如下:1.
- dom4j是一个非常优秀的Java XML API,具有性能优异、功能强大和极端易用使用的特点,同时它也是一个开放源工具。可以在这个地址ht
- 在项目开发中,经常碰到map转实体对象或者对象转map的场景,工作中,很多时候我们可能比较喜欢使用第三方jar包的API对他们进行转化,而且
- 演示代码如下:package swt_jface.demo11; import org.eclipse.swt.SWT; import or
- 这篇文章主要介绍了java实现上传文件类型检测过程解析,文中通过示例代码介绍的非常详细,对大家的学习或者工作具有一定的参考学习价值,需要的朋
- 由于近来学习java,遇到了一些在c++上没有的概念,将它记录下,以自己复习使用,如有不理解妥之处,望大家批评指导。资料均由网上经过自己整合
- 1、一个示例回顾Future一些业务场景我们需要使用多线程异步执行任务,加快任务执行速度。JDK5新增了Future接口,用于描述一个异步计
- ErrorPageFilter的实际应用Spring框架错误页过滤器springboot提供了一个ErrorPageFilter,用来处理当
- 前言本文准确来讲是探讨如何用 Jackson 来序列化 Apache avro 对象,因为简单用 Jackson 来序列化 Apache a
- 前言在Windows下JAVA用到的环境变量主要有3个,JAVA_HOME、CLASSPATH、PATH,下面来详细的介绍。JAVA_HOM