mybatis多数据源的配置和切换(oracle)

例如,要写一个通用框架。 使用者可以使用mysql也可以使用oracle。
在某种数据库下,可以使用2个数据源。

多个Configuration类的实现

命名空间可以解决这个问题。 在最开头加个特殊的名称。再和
@ConditionalOnProperty配合,如果没有这个属性,就不加载这个类。
如代码:

@ConditionalOnProperty(name = "admin.spring.datasource.driver-class-name", havingValue = "oracle.jdbc.driver.OracleDriver")
@Configuration
public class MysqlConfig {}

如oracle:

@ConditionalOnProperty(name = "admin.spring.datasource.driver-class-name", havingValue = "oracle.jdbc.driver.OracleDriver")
@Configuration
public class OracleConfig {}

不同数据库之间的区分

设置不同的接口扫描位置:

@MapperScan(basePackages = "com.ali.cloud.mapper.admin", sqlSessionTemplateRef  = "adminSqlSessionTemplate")

设置不同的xml映射位置:

sqlSessionFactoryBean.setMapperLocations(new PathMatchingResourcePatternResolver().getResources("classpath:/mapper/admin/oracle/*.xml"));

这样就实现了不同mapper可以使用不同数据库的数据。

多数据源通过命名空间来区分:
配置如下

admin.spring.datasource.driver-class-name=oracle.jdbc.driver.OracleDriver
admin.spring.datasource.url=jdbc\:oracle\:thin:@192.168.0.1\:1521\:testdb1
admin.spring.datasource.username=admin
admin.spring.datasource.password=1234

#zhangsan
zhangsan.spring.datasource.driver-class-name=oracle.jdbc.driver.OracleDriver
zhangsan.spring.datasource.url=jdbc\:oracle\:thin:@192.168.0.1\:1521\:testdb1
zhangsan.spring.datasource.username=zhangsan
zhangsan.spring.datasource.password=1234
  • 0
    点赞
  • 0
    收藏
    觉得还不错? 一键收藏
  • 0
    评论

“相关推荐”对你有帮助么?

  • 非常没帮助
  • 没帮助
  • 一般
  • 有帮助
  • 非常有帮助
提交
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值