【Java】 spring boot使用spring jdbc连接多个数据库


application.yml里的配置如下,注意要使用jdbc-url,否则会出现jdbcUrl is required with driverClassName:

复制代码
spring:
datasource:
test1:
driver-class-name: xxx
jdbc-url: xxx
username: xxx
password: xxx

test2:
driver-class-name: xxx
jdbc-url: xxx
username: xxx
password: xxx
 
 
复制代码

DataSourceConfig,一般就找个config文件夹放着:

复制代码
import javax.sql.DataSource; import org.springframework.beans.factory.annotation.Qualifier; import org.springframework.boot.context.properties.ConfigurationProperties; import org.springframework.context.annotation.Bean; import org.springframework.context.annotation.Configuration; import org.springframework.context.annotation.Primary; import org.springframework.jdbc.core.JdbcTemplate; import org.springframework.boot.jdbc.DataSourceBuilder; @Configuration public class DataSourceConfig { @Bean(name = "primaryDataSource") @Qualifier("primaryDataSource") @ConfigurationProperties(prefix="spring.datasource.primary") public DataSource primaryDataSource() { return DataSourceBuilder.create().build(); } @Bean(name = "secondaryDataSource") @Qualifier("secondaryDataSource") @Primary @ConfigurationProperties(prefix="spring.datasource.secondary") public DataSource secondaryDataSource() { return DataSourceBuilder.create().build(); } @Bean(name="primaryJdbcTemplate") public JdbcTemplate primaryJdbcTemplate (@Qualifier("primaryDataSource") DataSource dataSource ) { return new JdbcTemplate(dataSource); } @Bean(name="secondaryJdbcTemplate") public JdbcTemplate secondaryJdbcTemplate(@Qualifier("secondaryDataSource") DataSource dataSource) { return new JdbcTemplate(dataSource); } }
复制代码

在dao层,也就是实际从数据库查询数据的那一层,这样使用,在Qualifier后写需要的连接配置:

@Autowired
@Qualifier("primaryJdbcTemplate") public JdbcTemplate jdbcTemplate;

 

特别注意一不小心会报错 jdbcUrl is required with driverClassName 。

 

引用地址:https://www.cnblogs.com/lihan829/p/9637993.html


免责声明!

本站转载的文章为个人学习借鉴使用,本站对版权不负任何法律责任。如果侵犯了您的隐私权益,请联系本站邮箱yoyou2525@163.com删除。



 
粤ICP备18138465号  © 2018-2025 CODEPRJ.COM