Spring Boot多数据源及其事务管理配置方法
准备工作
先给我们的项目添加Spring-JDBC依赖和需要访问数据库的驱动依赖。
配置文件
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 publicclassJdbcConfig{ }
配置数据源
给其中一个数据源加上@Primary。因为在SpringBootJdbc的自动配置过程中,会对于开发者透明地使用dataSource进行一些相关配置,所以当有两个Datasource实现类时,SpringBoot将无法确定使用哪一个。
当我们不为@Bean指定名字时,Spring会默认使用方法名作为Bean的名字,所以下面两个数据源的名字分别为prodDataSource和devDataSource。
@Bean @Primary @ConfigurationProperties(prefix="spring.datasource.prod") publicDataSourceprodDataSource(){ returnDataSourceBuilder.create().build(); } @Bean @ConfigurationProperties(prefix="spring.datasource.dev") publicDataSourcedevDataSource(){ returnDataSourceBuilder.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。
@Bean publicJdbcOperationsprodJdbcOperations(DataSourceprodDataSource){ returnnewJdbcTemplate(prodDataSource); } @Bean publicJdbcOperationsdevJdbcOperations(DataSourcedevDataSource){ returnnewJdbcTemplate(devDataSource); }
使用
直接注入JdbcOperations即可
如上文的说明,不需要@Qualifier等的注解。
@Autowired privateJdbcOperationsdevJdbcOperations; @Autowired privateJdbcOperationsprodJdbcOperations;
事务配置
开启事务管理功能
在项目入口类,添加以下注解开启事务管理功能。
@EnableTransactionManagement
配置事务管理器
@Bean publicPlatformTransactionManagerprodTransactionManager(DataSourceprodDataSource){ returnnewDataSourceTransactionManager(prodDataSource); } @Bean publicPlatformTransactionManagerdevTransactionManager(DataSourcesitDataSource){ returnnewDataSourceTransactionManager(sitDataSource); }
使用
使用时只需在需要事务的方法添加注解@Transactional,并指定其value值即可。同样的,value值与相应的方法名相匹配即可。
@Transactional(value="prodTransactionManager") publicvoidprod(){ prodJdbcOperations.queryForList("SELECT*FROMUSER"); } @Transactional(value="devTransactionManager") publicvoiddev(){ devJdbcOperations.queryForList("SELECT*FROMUSER"); }
注意,@Transactional配置事务有很多限制,如方法必须为public,同一个类中无该注解的方法调用有注解的方法事务不生效等。该注解还可以配置在接口类等地方,具体用法请参考Spring官方文档相应章节http://docs.spring.io/spring-framework/docs/4.2.x/spring-framework-reference/html/transaction.html
以上就是本文的全部内容,希望对大家的学习有所帮助,也希望大家多多支持毛票票。