前往小程序,Get更优阅读体验!
立即前往
首页
学习
活动
专区
工具
TVP
发布
社区首页 >专栏 >Mybatis Plus 同时支持不同数据源DatabaseId

Mybatis Plus 同时支持不同数据源DatabaseId

作者头像
十毛
发布2022-07-28 08:40:41
3K0
发布2022-07-28 08:40:41
举报

项目开始的时候我们使用的是MySQL,但是一些客户要求使用国产瀚高数据库,所以只能同时支持MySQL和瀚高数据库(兼容pg语法)。mybatis-plus可以使用databaseId的方式支持多数据库厂商。

MyBatis的方式

  • mybatis-config.xml添加多数据库厂商支持
代码语言:javascript
复制
  <databaseIdProvider type="DB_VENDOR">
        <property name="Oracle" value="oracle"/>
        <property name="MySQL" value="mysql"/>
        <property name="DB2" value="d2"/>
        <property name="PostgreSQL" value="pg"/>
    </databaseIdProvider>
  • person_mapper.xml:每一个SQL语句中添加databaseId mybatis搜索sql语句的时候,会搜索databaseId与当前数据库相同厂商的语句以及没有配置databaseId的语句
代码语言:javascript
复制
<mapper namespace="com.tenmao.mybatis.PersonMapper">
    <select id="selectByPersonId" databaseId="mysql" resultType="com.tenmao.mybatis.Person">
        SELECT * FROM person WHERE id=#{id}
    </select>
    <select id="selectByPersonId" databaseId="pg" resultType="com.tenmao.mybatis.Person">
        SELECT * FROM person WHERE id=#{id}
    </select>
</mapper>

MyBatisi-Plus的支持方式

上面在mybatis-config.xml配置的方式在mybatis-plus不生效

  • 使用Java bean的方式,返回DatabaseIdProvider
代码语言:javascript
复制
@Bean
public DatabaseIdProvider databaseIdProvider() {
    VendorDatabaseIdProvider databaseIdProvider = new VendorDatabaseIdProvider();
    Properties properties = new Properties();
    properties.put("Oracle","oracle");
    properties.put("MySQL","mysql");
    properties.put("PostgreSQL","pg");
    databaseIdProvider.setProperties(properties);
    return databaseIdProvider;
}

参考

本文参与 腾讯云自媒体分享计划,分享自作者个人站点/博客。
原始发表:2022-07-14,如有侵权请联系 cloudcommunity@tencent.com 删除

本文分享自 作者个人站点/博客 前往查看

如有侵权,请联系 cloudcommunity@tencent.com 删除。

本文参与 腾讯云自媒体分享计划  ,欢迎热爱写作的你一起参与!

评论
登录后参与评论
0 条评论
热度
最新
推荐阅读
目录
  • MyBatis的方式
  • MyBatisi-Plus的支持方式
  • 参考
相关产品与服务
云数据库 SQL Server
腾讯云数据库 SQL Server (TencentDB for SQL Server)是业界最常用的商用数据库之一,对基于 Windows 架构的应用程序具有完美的支持。TencentDB for SQL Server 拥有微软正版授权,可持续为用户提供最新的功能,避免未授权使用软件的风险。具有即开即用、稳定可靠、安全运行、弹性扩缩等特点。
领券
问题归档专栏文章快讯文章归档关键词归档开发者手册归档开发者手册 Section 归档