Spring Boot多數(shù)據(jù)源及其事務(wù)管理配置
[TOC]
準(zhǔn)備工作
先給我們的項(xiàng)目添加Spring-JDBC依賴和需要訪問數(shù)據(jù)庫(kù)的驅(qū)動(dòng)依賴化漆。
配置文件
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ù)源
- 給其中一個(gè)數(shù)據(jù)源加上
@Primary
凹蜂。因?yàn)樵赟pring Boot Jdbc的自動(dòng)配置過程中瘟芝,會(huì)對(duì)于開發(fā)者透明地使用dataSource進(jìn)行一些相關(guān)配置俱笛,所以當(dāng)有兩個(gè)Datasource實(shí)現(xiàn)類時(shí),Spring Boot將無法確定使用哪一個(gè)妆够。 - 當(dāng)我們不為@Bean指定名字時(shí)识啦,Spring會(huì)默認(rèn)使用方法名作為Bean的名字,所以下面兩個(gè)數(shù)據(jù)源的名字分別為
prodDataSource
和devDataSource
神妹。
@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時(shí)指定前綴為a.b.c
配置JdbcTemplate
- 在此我們返回的不是
JdbcTemplate
的實(shí)現(xiàn)鸵荠,而是其實(shí)現(xiàn)接口JdbcOperations
冕茅。 - 使用
@Qualifier
注解指定該注入哪個(gè)bean,默認(rèn)名字為定義該bean的方法名。
@Bean
public JdbcOperations prodJdbcOperations(@Qualifier("prodDataSource") DataSource prodDataSource) {
return new JdbcTemplate(prodDataSource);
}
@Bean
public JdbcOperations devJdbcOperations(@Qualifier("devDataSource") DataSource devDataSource) {
return new JdbcTemplate(devDataSource);
}
使用
- 直接注入
JdbcOperations
即可
@Autowired
private JdbcOperations devJdbcOperations;
@Autowired
private JdbcOperations prodJdbcOperations;
事務(wù)配置
開啟事務(wù)管理功能
在項(xiàng)目入口類姨伤,添加以下注解開啟事務(wù)管理功能哨坪。
@EnableTransactionManagement
配置事務(wù)管理器
@Bean
public PlatformTransactionManager prodTransactionManager(@Qualifier("prodDataSource") DataSource prodDataSource) {
return new DataSourceTransactionManager(prodDataSource);
}
@Bean
public PlatformTransactionManager devTransactionManager(@Qualifier("devDataSource") DataSource sitDataSource) {
return new DataSourceTransactionManager(sitDataSource);
}
使用
使用時(shí)只需在需要事務(wù)的方法添加注解@Transactional
,并指定其value值即可姜挺。同樣的齿税,value值與相應(yīng)的方法名相匹配即可。
@Transactional(value = "prodTransactionManager")
public void prod() {
prodJdbcOperations.queryForList("SELECT * FROM USER");
}
@Transactional(value = "devTransactionManager")
public void dev() {
devJdbcOperations.queryForList("SELECT * FROM USER");
}
注意炊豪,@Transactional配置事務(wù)有很多限制凌箕,如方法必須為public,同一個(gè)類中無該注解的方法調(diào)用有注解的方法事務(wù)不生效等词渤。該注解還可以配置在接口類等地方牵舱,具體用法請(qǐng)參考Spring官方文檔相應(yīng)章節(jié) http://docs.spring.io/spring-framework/docs/4.2.x/spring-framework-reference/html/transaction.html