一、数据源配置

数据源配置

单数据源

使用h2数据库,springboot默认配置数据源信息。可以直接在调用对象中使用@Autowired注解注入Datasource对象或JdbcTemplate对象。

多数据源

可以使用排除springboot的自动配置功能,自己进行相应的配置:

  1. 在启动类上排除相应的自动配置项:
@SpringBootApplication(exclude = {DataSourceAutoConfiguration.class,
   	DataSourceTransactionManagerAutoConfiguration.class,
   	JdbcTemplateAutoConfiguration.class})
public class DemoApplication{
   public static void main(String[] args) {
   	SpringApplication.run(DemoApplication.class, args);
   }
}
  1. 在Configuration配置类中配置相应的bean。
@Configuration
public class DataSourceConfig {
   private Logger log = LoggerFactory.getLogger(this.getClass());

   @Bean
   @ConfigurationProperties("foo.datasource")
   public DataSourceProperties fooDataSourceProperties(){
       return new DataSourceProperties();
   }

   @Bean
   public DataSource fooDataSource(){
       DataSourceProperties dataSourceProperties = fooDataSourceProperties();
       log.info("foo datasource : {}", dataSourceProperties.getUrl());
       return dataSourceProperties.initializeDataSourceBuilder().build();
   }
   
   @Bean
   public PlatformTransactionManager fooTxManager(){
       return new DataSourceTransactionManager(fooDataSource());
   }
   
   @Bean
   @ConfigurationProperties("bar.datasource")
   public DataSourceProperties barDataSourceProperties(){
       return new DataSourceProperties();
   }
   
   @Bean
   public DataSource barDataSource(){
       DataSourceProperties dataSourceProperties = barDataSourceProperties();
       log.info("bar datasource: {}", dataSourceProperties.getUrl());
       return dataSourceProperties.initializeDataSourceBuilder().build();
   }
   
   @Bean
   public PlatformTransactionManager barTxManager(){
       return new DataSourceTransactionManager(barDataSource());
   }
   
}
  1. 在application.yml中添加两个数据源对应的配置项:
foo:
 datasource:
   url: jdbc:h2:mem:foo
   username: sa
   password:
bar:
 datasource:
   url: jdbc:h2:mem:bar
   username: sa
   password:
  1. 在使用datasource的对象中注入datasource对象时,使用@Qualifier注解标识需要注入哪个DataSource对象:
@Autowired
   @Qualifier("fooDataSource")
   private DataSource dataSource;
  • 0
    点赞
  • 0
    收藏
    觉得还不错? 一键收藏
  • 0
    评论

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

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

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值