例如,要写一个通用框架。 使用者可以使用mysql也可以使用oracle。
在某种数据库下,可以使用2个数据源。
多个Configuration类的实现
命名空间可以解决这个问题。 在最开头加个特殊的名称。再和
@ConditionalOnProperty配合,如果没有这个属性,就不加载这个类。
如代码:
@ConditionalOnProperty(name = "admin.spring.datasource.driver-class-name", havingValue = "com.mysql.jdbc.Driver")
@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
来源:CSDN
作者:chushiyunen
链接:https://blog.csdn.net/enthan809882/article/details/104307961