Mybatis-plus

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

2022-07-13  本文已影响0人  十毛tenmao

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

MyBatis的方式

  <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>
<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不生效

@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;
}

参考

上一篇 下一篇

猜你喜欢

热点阅读