[TOC]html
先给咱们的项目添加Spring-JDBC依赖和须要访问数据库的驱动依赖。java
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
首先创建Java配置类,为其添加上注解@Configuration
。mysql
@Configuration public class JdbcConfig { }
@Primary
。由于在Spring Boot Jdbc的自动配置过程当中,会对于开发者透明地使用dataSource进行一些相关配置,因此当有两个Datasource实现类时,Spring Boot将没法肯定使用哪个。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
spring
JdbcTemplate
的实现,而是其实现接口JdbcOperations
。@Qualifier
注解指定该注入哪一个bean,默认名字为定义该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;
在项目入口类,添加如下注解开启事务管理功能。sql
@EnableTransactionManagement
@Bean public PlatformTransactionManager prodTransactionManager(@Qualifier("prodDataSource") DataSource prodDataSource) { return new DataSourceTransactionManager(prodDataSource); } @Bean public PlatformTransactionManager devTransactionManager(@Qualifier("devDataSource") 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官方文档相应章节 http://docs.spring.io/spring-framework/docs/4.2.x/spring-framework-reference/html/transaction.htmlui