I am having issues creating a spring boot application that can dynamically connect to multiple databases, depending on user input. Basically the application runs the same sql query on different databases. modeling my attempt after this, i have received the following error:
2018-04-10 16:18:50.678 ERROR 15716 --- [ restartedMain] com.zaxxer.hikari.HikariConfig : HikariPool-1 - dataSource or dataSourceClassName or jdbcUrl is required.
--
Caused by: java.lang.IllegalArgumentException: dataSource or dataSourceClassName or jdbcUrl is required.
config class:
@Configuration
public class ReconDBConfig {
@ConfigurationProperties(prefix = "spring.datasource.foo")
@Bean
@Primary
public DataSource fooDataSource() {
return DataSourceBuilder
.create()
.build();
}
@ConfigurationProperties(prefix = "spring.datasource.bar")
@Bean
public DataSource barDataSource() {
return DataSourceBuilder
.create()
.build();
}
}
Properties file:
spring.datasource.foo.url = jdbc:postgresql://localhost:5432/fooDB
spring.datasource.foo.user = admin
spring.datasource.foo.password = admin
spring.datasource.foo.driver = org.postgresql.Driver
spring.datasource.foo.maxconn = 5
spring.datasource.foo.expiry = 180
spring.datasource.foo.cache = true
spring.datasource.foo.retry = 3
spring.datasource.foo.retrydelay = 30
spring.datasource.bar.url = jdbc:postgresql://not_localhost:5432/fooDB
spring.datasource.bar.user = definitely_not_admin
spring.datasource.bar.password = definitely_not_admin
spring.datasource.bar.driver = org.postgresql.Driver
spring.datasource.bar.maxconn = 5
spring.datasource.bar.expiry = 180
spring.datasource.bar.cache = true
spring.datasource.bar.retry = 3
spring.datasource.bar.retrydelay = 30
any ideas on how i can accomplish this? i am, as you can tell, not super savvy with this multiple db configuration yet.