溫馨提示×

溫馨提示×

您好,登錄后才能下訂單哦!

密碼登錄×
登錄注冊×
其他方式登錄
點擊 登錄注冊 即表示同意《億速云用戶服務條款》

Spring Boot多數(shù)據(jù)源及其事務管理配置方法

發(fā)布時間:2020-09-22 20:55:37 來源:腳本之家 閱讀:153 作者:lzp4ever 欄目:編程語言

準備工作

先給我們的項目添加Spring-JDBC依賴和需要訪問數(shù)據(jù)庫的驅動依賴。

配置文件

spring.datasource.prod.driverClassName=com.mysql.jdbc.Driver
spring.datasource.prod.url=jdbc:mysql://127.0.0.1:3306/prod
spring.datasource.prod.username=root
spring.datasource.prod.password=123456

spring.datasource.dev.driverClassName=com.mysql.jdbc.Driver
spring.datasource.dev.url=jdbc:mysql://127.0.0.1:3306/dev
spring.datasource.dev.username=root
spring.datasource.dev.password=123456

JavaConfig

首先建立Java配置類,為其添加上注解@Configuration。

@Configuration
public class JdbcConfig {

}

配置數(shù)據(jù)源

給其中一個數(shù)據(jù)源加上@Primary。因為在Spring Boot Jdbc的自動配置過程中,會對于開發(fā)者透明地使用dataSource進行一些相關配置,所以當有兩個Datasource實現(xiàn)類時,Spring Boot將無法確定使用哪一個。

當我們不為@Bean指定名字時,Spring會默認使用方法名作為Bean的名字,所以下面兩個數(shù)據(jù)源的名字分別為prodDataSourcedevDataSource。

@Bean
@Primary
@ConfigurationProperties(prefix = "spring.datasource.prod")
public DataSource prodDataSource(){
 return DataSourceBuilder.create().build();
}

@Bean
@ConfigurationProperties(prefix = "spring.datasource.dev")
public DataSource devDataSource(){
 return DataSourceBuilder.create().build();
}

配置文件里的屬性名是不需要寫成spring.datasource.xxx的形式的,寫成a.b.c.url也沒有問題,只要在配置bean時指定前綴為a.b.c

配置JdbcTemplate

在此我們返回的不是JdbcTemplate的實現(xiàn),而是其實現(xiàn)接口JdbcOperations。

Bean的入?yún)pring會自動其相符合的Bean注入,所以在此我們不需要@Autowired相應的Bean再使用。

Spring會將變量名與Bean的名字做關聯(lián)。在此我們入?yún)?shù)據(jù)源的名稱和上面數(shù)據(jù)源Bean的方法名相匹配,所以也不需要用@Qualifier注解指定是哪個Bean。

@Bean
public JdbcOperations prodJdbcOperations(DataSource prodDataSource) {
 return new JdbcTemplate(prodDataSource);
}

@Bean
public JdbcOperations devJdbcOperations(DataSource devDataSource) {
 return new JdbcTemplate(devDataSource);
}

使用

直接注入JdbcOperations即可

如上文的說明,不需要@Qualifier等的注解。

 @Autowired
 private JdbcOperations devJdbcOperations;

 @Autowired
 private JdbcOperations prodJdbcOperations;

事務配置

開啟事務管理功能

在項目入口類,添加以下注解開啟事務管理功能。

@EnableTransactionManagement

配置事務管理器

@Bean
public PlatformTransactionManager prodTransactionManager(DataSource prodDataSource) {
 return new DataSourceTransactionManager(prodDataSource);
}

@Bean
public PlatformTransactionManager devTransactionManager(DataSource sitDataSource) {
 return new DataSourceTransactionManager(sitDataSource);
}

使用

使用時只需在需要事務的方法添加注解@Transactional,并指定其value值即可。同樣的,value值與相應的方法名相匹配即可。

@Transactional(value = "prodTransactionManager")
public void prod() {
 prodJdbcOperations.queryForList("SELECT * FROM USER");
}

@Transactional(value = "devTransactionManager")
public void dev() {
 devJdbcOperations.queryForList("SELECT * FROM USER");
}

注意,@Transactional配置事務有很多限制,如方法必須為public,同一個類中無該注解的方法調用有注解的方法事務不生效等。該注解還可以配置在接口類等地方,具體用法請參考Spring官方文檔相應章節(jié)http://docs.spring.io/spring-framework/docs/4.2.x/spring-framework-reference/html/transaction.html

以上就是本文的全部內容,希望對大家的學習有所幫助,也希望大家多多支持億速云。

向AI問一下細節(jié)

免責聲明:本站發(fā)布的內容(圖片、視頻和文字)以原創(chuàng)、轉載和分享為主,文章觀點不代表本網(wǎng)站立場,如果涉及侵權請聯(lián)系站長郵箱:is@yisu.com進行舉報,并提供相關證據(jù),一經(jīng)查實,將立刻刪除涉嫌侵權內容。

AI