使用spring boot 改造老项目,因为数据源有多个,启动时一直报如下错误
Caused by: org.springframework.beans.factory.NoUniqueBeanDefinitionException: No qualifying bean of type [javax.sql.DataSource] is defined: expected single matching bean but found 5:
原来是
@EnableAutoConfiguration
这个注解会把sping的xml文件中配置的数据源全部都自动注入,不会像改造前那样会默认注入一个,当使用其他数据源时再调用另外的数据源。
根据spirng boot的官方文档,可以如下配置多个数据源
@Bean
@Primary
@ConfigurationProperties(prefix="datasource.primary")
public DataSource primaryDataSource() {
return DataSourceBuilder.create().build();
}
@Bean
@ConfigurationProperties(prefix="datasource.secondary")
public DataSource secondaryDataSource() {
return DataSourceBuilder.create().build();
}
但是,既然是改造老项目,当然是改动越少越好。
于是可以通过如下的方式禁止springboot自动注入多个数据源
@SpringBootApplication
@EnableAutoConfiguration(exclude={
DataSourceAutoConfiguration.class,
HibernateJpaAutoConfiguration.class, //(如果使用Hibernate时,需要加)
DataSourceTransactionManagerAutoConfiguration.class,
})
@ImportResource({"classpath:spring-servlet.xml"})
public class JzApplication {
public static void main(String[] args) throws Exception {
ApplicationContext ctx = SpringApplication.run(JzApplication .class,args);
}
}
改完后,启动项目,不再提示注入失败,读取数据库也正常。