Spring Boot多數(shù)據(jù)源及其事務(wù)管理配置方法
準(zhǔn)備工作
先給我們的項(xiàng)目添加Spring-JDBC依賴和需要訪問數(shù)據(jù)庫的驅(qū)動依賴。
配置文件
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
。因?yàn)樵赟pring Boot Jdbc的自動配置過程中,會對于開發(fā)者透明地使用dataSource進(jìn)行一些相關(guān)配置,所以當(dāng)有兩個Datasource實(shí)現(xiàn)類時,Spring Boot將無法確定使用哪一個。
當(dāng)我們不為@Bean指定名字時,Spring會默認(rèn)使用方法名作為Bean的名字,所以下面兩個數(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時指定前綴為a.b.c
配置JdbcTemplate
在此我們返回的不是JdbcTemplate
的實(shí)現(xiàn),而是其實(shí)現(xiàn)接口JdbcOperations
。
Bean的入?yún)pring會自動其相符合的Bean注入,所以在此我們不需要@Autowired相應(yīng)的Bean再使用。
Spring會將變量名與Bean的名字做關(guān)聯(lián)。在此我們?nèi)雲(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;
事務(wù)配置
開啟事務(wù)管理功能
在項(xiàng)目入口類,添加注解開啟事務(wù)管理功能。
@EnableTransactionManagement
配置事務(wù)管理器
@Bean public PlatformTransactionManager prodTransactionManager(DataSource prodDataSource) { return new DataSourceTransactionManager(prodDataSource); } @Bean public PlatformTransactionManager devTransactionManager(DataSource sitDataSource) { return new DataSourceTransactionManager(sitDataSource); }
使用
使用時只需在需要事務(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,同一個類中無該注解的方法調(diào)用有注解的方法事務(wù)不生效等。該注解還可以配置在接口類等地方,具體用法請參考Spring官方文檔相應(yīng)章節(jié)http://docs.spring.io/spring-framework/docs/4.2.x/spring-framework-reference/html/transaction.html
以上就是本文的全部內(nèi)容,希望對大家的學(xué)習(xí)有所幫助,也希望大家多多支持腳本之家。
相關(guān)文章
SpringBoot 如何自定義請求參數(shù)校驗(yàn)
這篇文章主要介紹了SpringBoot 如何自定義請求參數(shù)校驗(yàn)方式,具有很好的參考價值,希望對大家有所幫助。如有錯誤或未考慮完全的地方,望不吝賜教2021-10-10Maven環(huán)境安裝配置和新建項(xiàng)目介紹
這篇文章介紹了Maven環(huán)境安裝配置和新建項(xiàng)目介紹,對大家的學(xué)習(xí)或者工作具有一定的參考學(xué)習(xí)價值,需要的朋友們下面隨著小編來一起學(xué)習(xí)學(xué)習(xí)吧2021-12-12Springboot @Validated和@Valid的區(qū)別及使用詳解
這篇文章主要介紹了Springboot @Validated和@Valid的區(qū)別及使用詳解,文中通過示例代碼介紹的非常詳細(xì),對大家的學(xué)習(xí)或者工作具有一定的參考學(xué)習(xí)價值,需要的朋友們下面隨著小編來一起學(xué)習(xí)學(xué)習(xí)吧2020-05-05Java常見基礎(chǔ)數(shù)據(jù)結(jié)構(gòu)
這篇文章主要介紹了Java常見數(shù)據(jù)結(jié)構(gòu)面試題,帶有答案及解釋,希望對廣大的程序愛好者有所幫助,同時祝大家有一個好成績,需要的朋友可以參考下,希望可以幫助到你2021-07-07