springboot v2.0.3版本多数据源配置方法

网友投稿 287 2023-01-19


springboot v2.0.3版本多数据源配置方法

本篇分享的是springboot多数据源配置,在从springboot v1.5版本升级到v2.0.3时,发现之前写的多数据源的方式不可用了,捕获错误信息如:

异常:jdbcUrl is required with driverClassName.

先来说下之前的多数据源配置如:

spring:

datasource:

url: jdbc:sqlserver://192.168.122.111;DatabaseName=flight

username: sa

password: 1234.abcd

driver-class-name: com.microsoft.sqlserver.jdbc.SQLServerDriver

seconddatasource:

url: jdbc:sqlserver://192.168.122.111;DatabaseName=flight2

username: http://sa

password: 1234.abcd

driver-class-name: com.microsoft.sqlserver.jdbc.SQLServerDriver

配置了两个数据库,在原来默认的datasouHJzsvhwrce节点下面增加了seconddatasource节http://点的配置,然后主要的代码如:

@Primary

@Bean

@ConfigurationProperties(prefix = "spring.seconddatasource")

public DataSource dataSource() {

return DataSourceBuilder.create().build();

}

http://@Bean(name = "secodDataSource")

@ConfigurationProperties(prefix = "spring.seconddatasource")

public DataSource secodDataSource() {

return DataSourceBuilder.create().build();

}

@Primary

@Bean

public JdbcTemplate jdbcTemplate(DataSource dataSource) {

return new JdbcTemplate(dataSource);

}

@Bean(name = "secondJdbcTemplate")

public JdbcTemplate secondJdbcTemplate(@Qualifier(value = "secodDataSource") DataSource dataSource) {

return new JdbcTemplate(dataSource);

}

来创建两个不同的jdbctemplate,到这里老版本这样干没有啥问题,能够正常的得到数据;而升级未V2.03版本的时候提示:异常:jdbcUrl is required with driverClassName.

很显然配置节点不能使用导致的,配置节点名字变了,要解决这问题这里使用了托管DataSourceProperties的方式来对数据配置从新赋值,具体代码如:

@Bean

@Primary

@ConfigurationProperties(prefix = "spring.datasource")

public DataSourceProperties dataSourceProperties(){

return new DataSourceProperties();

}

@Bean("secondProperties")

@ConfigurationProperties(prefix = "spring.seconddatasource")

public DataSourceProperties secondProperties(){

return new DataSourceProperties();

}

@Primary

@Bean

public DataSource dataSource(DataSourceProperties dataSourceProperties) {

return dataSourceProperties.initializeDataSourceBuilder().build();

}

@Bean(name = "secodDataSource")

public DataSource secodDataSource(@Qualifier(value = http://"secondProperties") DataSourceProperties dataSourceProperties) {

return dataSourceProperties.initializeDataSourceBuilder().build();

}

能够看出多了一级DataSourceProperties的创建,此时能够运行出结果如:

除了编码的这种方式也可以采用上面说的既然是配置找不到,那配置肯定是改名了,根据错误提示我们不放把url改名未jdbc-url,具体如下:

此刻我们再来运行,同样的也能出来数据;两种方式处理v2.03版本数据源问题:

•编码配置DataSourceProperties

•通过配置jdbc-url

通过数据源配置节点名变动的问题,引发了springboot在升级迭代的过程中一些细微的变动,这或许会给我们在学习和升级过程中造成麻烦,所以官网每次升级的内容说明还是有必要看下的。

总结

以上所述是给大家介绍的springboot v2.0.3版本多数据源配置方法,希望对大家有所帮助,如果大家有任何疑问请给我留言,会及时回复大家的。在此也非常感谢大家对我们网站的支持!


版权声明:本文内容由网络用户投稿,版权归原作者所有,本站不拥有其著作权,亦不承担相应法律责任。如果您发现本站中有涉嫌抄袭或描述失实的内容,请联系我们jiasou666@gmail.com 处理,核实后本网站将在24小时内删除侵权内容。

上一篇:科技企业研发管理平台(研发管理平台软件)
下一篇:实现接口格式(接口语法格式)
相关文章

 发表评论

暂时没有评论,来抢沙发吧~