文章详情

短信预约-IT技能 免费直播动态提醒

请输入下面的图形验证码

提交验证

短信预约提醒成功

Mybatis-plus支持Gbase8s分页的实现示例

2024-04-02 19:55

关注

需求

实现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", "南大通用数据库"),

在这里插入图片描述

新增一个方言实现类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的分页参数是最前面两个,所以出现参数位置匹配不正确的问题!当然,如果仅有两个分页参数则不影响

解决方案如下:


	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.完善内容原理如下:

到此这篇关于Mybatis-plus支持Gbase8s分页的实现示例的文章就介绍到这了,更多相关Mybatis-plus Gbase8s分页 内容请搜索编程网以前的文章或继续浏览下面的相关文章希望大家以后多多支持编程网!

阅读原文内容投诉

免责声明:

① 本站未注明“稿件来源”的信息均来自网络整理。其文字、图片和音视频稿件的所属权归原作者所有。本站收集整理出于非商业性的教育和科研之目的,并不意味着本站赞同其观点或证实其内容的真实性。仅作为临时的测试数据,供内部测试之用。本站并未授权任何人以任何方式主动获取本站任何信息。

② 本站未注明“稿件来源”的临时测试数据将在测试完成后最终做删除处理。有问题或投稿请发送至: 邮箱/279061341@qq.com QQ/279061341

软考中级精品资料免费领

  • 历年真题答案解析
  • 备考技巧名师总结
  • 高频考点精准押题
  • 2024年上半年信息系统项目管理师第二批次真题及答案解析(完整版)

    难度     813人已做
    查看
  • 【考后总结】2024年5月26日信息系统项目管理师第2批次考情分析

    难度     354人已做
    查看
  • 【考后总结】2024年5月25日信息系统项目管理师第1批次考情分析

    难度     318人已做
    查看
  • 2024年上半年软考高项第一、二批次真题考点汇总(完整版)

    难度     435人已做
    查看
  • 2024年上半年系统架构设计师考试综合知识真题

    难度     224人已做
    查看

相关文章

发现更多好内容

猜你喜欢

AI推送时光机
位置:首页-资讯-后端开发
咦!没有更多了?去看看其它编程学习网 内容吧
首页课程
资料下载
问答资讯