当前位置: 首页 > news >正文

mybatisPlus分页方言设置错误问题 mybatisPlus对于Oceanbase的Oracle租户分页识别错误

问题描述

Oceanbase的Oracle租户时分页报错不认识Limit,由于Limit是mysql的分页形式,这里认为应该是Oceanbase的Oracle租户被错误的识别成了mysql方言


原因分析:

观察pageInteceptor拦截器配置

@Beanpublic MybatisPlusInterceptor mybatisPlusInterceptor() {MybatisPlusInterceptor interceptor = new MybatisPlusInterceptor();PaginationInnerInterceptor paginationInnerInterceptor = new PaginationInnerInterceptor();//多数据源不能写死DbType// paginationInnerInterceptor.setDbType(DbType.ORACLE);paginationInnerInterceptor.setOverflow(false);interceptor.addInnerInterceptor(paginationInnerInterceptor);return interceptor;}

发现使用的拦截器PaginationInnerInterceptor中配置获取方言的逻辑为

    /*** 获取分页方言类的逻辑** @param executor Executor* @return 分页方言类*/protected IDialect findIDialect(Executor executor) {if (dialect != null) {return dialect;}if (dbType != null) {dialect = DialectFactory.getDialect(dbType);return dialect;}return DialectFactory.getDialect(JdbcUtils.getDbType(executor));}

其中DialectFactory.getDialect方法为

public static IDialect getDialect(DbType dbType) {IDialect dialect = DIALECT_ENUM_MAP.get(dbType);if (null == dialect) {if (dbType == DbType.OTHER) {throw ExceptionUtils.mpe("%s database not supported.", dbType.getDb());}// mysql same typeelse if (dbType == DbType.MYSQL|| dbType == DbType.MARIADB|| dbType == DbType.GBASE|| dbType == DbType.OSCAR|| dbType == DbType.XU_GU|| dbType == DbType.CLICK_HOUSE|| dbType == DbType.OCEAN_BASE|| dbType == DbType.CUBRID|| dbType == DbType.SUNDB) {dialect = new MySqlDialect();}// oracle same typeelse if (dbType == DbType.ORACLE|| dbType == DbType.DM|| dbType == DbType.GAUSS) {dialect = new OracleDialect();}// postgresql same typeelse if (dbType == DbType.POSTGRE_SQL|| dbType == DbType.H2|| dbType == DbType.LEALONE|| dbType == DbType.SQLITE|| dbType == DbType.HSQL|| dbType == DbType.KINGBASE_ES|| dbType == DbType.PHOENIX|| dbType == DbType.SAP_HANA|| dbType == DbType.IMPALA|| dbType == DbType.HIGH_GO|| dbType == DbType.VERTICA|| dbType == DbType.REDSHIFT|| dbType == DbType.OPENGAUSS|| dbType == DbType.TDENGINE|| dbType == DbType.UXDB|| dbType == DbType.GBASE8S_PG|| dbType == DbType.GBASE_8C) {dialect = new PostgreDialect();}// other typeselse if (dbType == DbType.ORACLE_12C|| dbType == DbType.FIREBIRD|| dbType == DbType.SQL_SERVER) {dialect = new Oracle12cDialect();} else if (dbType == DbType.DB2) {dialect = new DB2Dialect();} else if (dbType == DbType.SQL_SERVER2005) {dialect = new SQLServer2005Dialect();} else if (dbType == DbType.SYBASE) {dialect = new SybaseDialect();} else if (dbType == DbType.XCloud) {dialect = new XCloudDialect();} else if (dbType == DbType.GBASE_8S|| dbType == DbType.GBASEDBT|| dbType == DbType.GBASE_INFORMIX|| dbType == DbType.SINODB) {dialect = new GBase8sDialect();} else if (dbType == DbType.INFORMIX) {dialect = new InformixDialect();} else if (dbType == DbType.TRINO|| dbType == DbType.PRESTO) {dialect = new TrinoDialect();}DIALECT_ENUM_MAP.put(dbType, dialect);}return dialect;}

此时发现oceanbase的方言设置为mysql
并未区分mysql租户和oracle租户


解决方案:

设置一个自定义拦截器MybatisPlusInterceptor

package com.xquant.xtam.common.datasource.support;import com.baomidou.mybatisplus.annotation.DbType;
import com.baomidou.mybatisplus.extension.plugins.inner.PaginationInnerInterceptor;
import com.baomidou.mybatisplus.extension.plugins.pagination.DialectFactory;
import com.baomidou.mybatisplus.extension.plugins.pagination.dialects.IDialect;
import com.baomidou.mybatisplus.extension.toolkit.JdbcUtils;
import org.apache.ibatis.executor.Executor;public class CustomPaginationInnerInterceptor extends PaginationInnerInterceptor {/*** 获取分页方言类的逻辑** @param executor Executor* @return 分页方言类*/@Overrideprotected IDialect findIDialect(Executor executor) {if (this.getDialect() != null) {return this.getDialect();}if (this.getDialect() != null) {this.setDialect(DialectFactory.getDialect(this.getDbType()));return this.getDialect();}// 这个地方特殊处理一下,认为 OceanBase 是 Oracle,无法处理 OceanBase 的Oracle租户DbType dbType = JdbcUtils.getDbType(executor);if (dbType == DbType.OCEAN_BASE) {dbType = DbType.ORACLE;}return DialectFactory.getDialect(dbType);}
}

也可以通过修改jdbc工具类,或者自定义方言形式去添加一些小众,不识别的方言配置

http://www.lryc.cn/news/579823.html

相关文章:

  • HarmonyOS免密认证方案 助力应用登录安全升级
  • 使用循环抵消算法求解最小费用流问题
  • Python 制作 pyd(Windows 平台的动态链接库)
  • 【行云流水ai笔记】粗粒度控制:推荐CTRL、GeDi 细粒度/多属性控制:推荐TOLE、GPT-4RL
  • 10分钟搭建 PHP 开发环境教程
  • Java对象哈希值深度解析
  • 支持向量机(SVM)在LIDC-IDRI数据集上的多分类实现(肺癌检测)
  • 三五法则的类的设计
  • 供应链管理:指标评估方式分类与详解
  • Rust 中的返回类型
  • 云原生Kubernetes系列 | etcd3.5集群部署和使用
  • Day51 复习日-模型改进
  • TCP、HTTP/1.1 和HTTP/2 协议
  • 怎么更改cursor字体大小
  • JavaEE初阶第七期:解锁多线程,从 “单车道” 到 “高速公路” 的编程升级(五)
  • ElasticSearch快速入门-1
  • MSPM0G3507学习笔记(一) 重置版:适配逐飞库的ti板环境配置
  • 服装零售企业跨区域运营难题破解方案
  • 如何将大型视频文件从 iPhone 传输到 PC
  • PoE 延长器——让网络部署更自由
  • 第十章:HIL-SERL 真实机器人训练实战
  • Docker拉取bladex 、 sentinel-dashboard
  • 【阿里巴巴JAVA开发手册】IDE的text file encoding设置为UTF-8; IDE中文件的换行符使用Unix格式,不要使用Windows格式。
  • Android BitmapRegionDecoder 详解
  • Java启动脚本
  • vue create 和npm init 创建项目对比
  • error MSB8041: 此项目需要 MFC 库。从 Visual Studio 安装程序(单个组件选项卡)为正在使用的任何工具集和体系结构安装它们。
  • React 渲染深度解密:从 JSX 到 DOM 的初次与重渲染全流程
  • 最快实现的前端灰度方案
  • 因果语言模型、自回归语言模型、仅解码器语言模型都是同一类模型