先給我們的項目添加Spring-JDBC依賴和需要訪問數據庫的驅動依賴。
配置文件
1
2
3
4
5
6
7
8
9
|
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
。
1
2
3
4
|
@Configuration public class JdbcConfig { } |
配置數據源
給其中一個數據源加上@Primary
。因為在Spring Boot Jdbc的自動配置過程中,會對于開發者透明地使用dataSource進行一些相關配置,所以當有兩個Datasource實現類時,Spring Boot將無法確定使用哪一個。
當我們不為@Bean指定名字時,Spring會默認使用方法名作為Bean的名字,所以下面兩個數據源的名字分別為prodDataSource
和devDataSource
。
1
2
3
4
5
6
7
8
9
10
11
12
|
@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
的實現,而是其實現接口JdbcOperations
。
Bean的入參Spring會自動其相符合的Bean注入,所以在此我們不需要@Autowired相應的Bean再使用。
Spring會將變量名與Bean的名字做關聯。在此我們入參數據源的名稱和上面數據源Bean的方法名相匹配,所以也不需要用@Qualifier注解指定是哪個Bean。
1
2
3
4
5
6
7
8
9
|
@Bean public JdbcOperations prodJdbcOperations(DataSource prodDataSource) { return new JdbcTemplate(prodDataSource); } @Bean public JdbcOperations devJdbcOperations(DataSource devDataSource) { return new JdbcTemplate(devDataSource); } |
使用
直接注入JdbcOperations
即可
如上文的說明,不需要@Qualifier
等的注解。
1
2
3
4
5
|
@Autowired private JdbcOperations devJdbcOperations; @Autowired private JdbcOperations prodJdbcOperations; |
事務配置
開啟事務管理功能
在項目入口類,添加以下注解開啟事務管理功能。
1
|
@EnableTransactionManagement |
配置事務管理器
1
2
3
4
5
6
7
8
9
|
@Bean public PlatformTransactionManager prodTransactionManager(DataSource prodDataSource) { return new DataSourceTransactionManager(prodDataSource); } @Bean public PlatformTransactionManager devTransactionManager(DataSource sitDataSource) { return new DataSourceTransactionManager(sitDataSource); } |
使用
使用時只需在需要事務的方法添加注解@Transactional
,并指定其value值即可。同樣的,value值與相應的方法名相匹配即可。
1
2
3
4
5
6
7
8
9
|
@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官方文檔相應章節http://docs.spring.io/spring-framework/docs/4.2.x/spring-framework-reference/html/transaction.html
以上就是本文的全部內容,希望對大家的學習有所幫助,也希望大家多多支持服務器之家。
原文鏈接:http://www.jianshu.com/p/9c4b78ef2a1d#