Spring boot + Mybatis Plus DatabaseId的使用
Mybatis中使用DatabaseId
Mybatis中如果需要对DatabaseId进行支持需要在配置 mybatis-config.xml 中加入如下配置
<databaseIdProvider type="DB_VENDOR">
<property name="MySQL" value="mysql"/>
<property name="Oracle" value="oracle" />
</databaseIdProvider>
加入这段配置所我们就可以在mapper.xml中这么使用了
<select id="selectAll" resultType="com.alen.trial.multilds.model.Multil" databaseId="mysql">
select * from multil
</select>
<select id="selectAll" resultType="com.alen.trial.multilds.model.Multil" databaseId="oracle">
select id from multil
</select>
那么在Mybatis plus中应该怎么用呢?
经过分析以上代码可知,Mybatis中提供一个接口DatabaseIdProvider来做数据库类型和sql中DatabaseId的映射,Mybatis通过上面的配置文件创建了一个实现DatabaseIdProvider的类并载入了映射配置,知道这一点就好办了,我们只需要提供一个同样的DatabaseIdProvider 实现类到Spring容器中应该就可以了,于是我在我的项目中加入了以下代码:
/**
为了配置管理我把这段代码加入到了 MybatisPlusConfig 中
*/
@Bean
public DatabaseIdProvider databaseIdProvider() {
VendorDatabaseIdProvider databaseIdProvider = new VendorDatabaseIdProvider();
Properties properties = new Properties();
properties.put("Oracle","oracle");
properties.put("MySQL","mysql");
databaseIdProvider.setProperties(properties);
return databaseIdProvider;
}
在application.yml中加入(这一步不是必须的,Mybatis会根据配置的数据源来判断数据库类型从而来选择使用哪个sql语句)
mybatis-plus:
mapper-locations: classpath*:com/alen/trial/multilds/dao/*.xml
global-config:
db-config:
# db-type: mysql
db-type: oracle
测试结果
首先使用oracle测试(注意这里的数据源要修改成oracle的数据源)
为了方便测试加入了以下接口
@GetMapping("/select/all")
public List<Multil> getDataFormMysqlA() {
return service.select();
}
使用mysql测试
对比一下配置
<select id="selectAll" resultType="com.alen.trial.multilds.model.Multil" databaseId="mysql">
select * from multil
</select>
<select id="selectAll" resultType="com.alen.trial.multilds.model.Multil" databaseId="oracle">
select id from multil
</select>
没有问题,就是乱码了有点小瑕疵!