Spring Boot多数据源及其事务管理配置
来源:互联网 发布:qq飞车皮皮虾改车软件 编辑:程序博客网 时间:2024/06/05 18:31
Spring Boot多数据源及其事务管理配置
- Spring Boot多数据源及其事务管理配置
- 准备工作
- 配置文件
- JavaConfig
- 配置数据源
- 配置JdbcTemplate
- 使用
- 事务配置
- 开启事务管理功能
- 配置事务管理器
- 使用
准备工作
先给我们的项目添加Spring-JDBC依赖和需要访问数据库的驱动依赖。
配置文件
spring.datasource.prod.driverClassName=com.mysql.jdbc.Driverspring.datasource.prod.url=jdbc:mysql://127.0.0.1:3306/prodspring.datasource.prod.username=rootspring.datasource.prod.password=123456spring.datasource.dev.driverClassName=com.mysql.jdbc.Driverspring.datasource.dev.url=jdbc:mysql://127.0.0.1:3306/devspring.datasource.dev.username=rootspring.datasource.dev.password=123456
JavaConfig
首先建立Java配置类,为其添加上注解@Configuration
。
@Configurationpublic class JdbcConfig {}
配置数据源
- 给其中一个数据源加上
@Primary
。因为在Spring Boot Jdbc的自动配置过程中,会对于开发者透明地使用dataSource进行一些相关配置,所以当有两个Datasource实现类时,Spring Boot将无法确定使用哪一个。 - 当我们不为@Bean指定名字时,Spring会默认使用方法名作为Bean的名字,所以下面两个数据源的名字分别为
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
的实现,而是其实现接口JdbcOperations
。 - 使用
@Qualifier
注解指定该注入哪个bean,默认名字为定义该bean的方法名。
@Beanpublic JdbcOperations prodJdbcOperations(@Qualifier("prodDataSource") DataSource prodDataSource) { return new JdbcTemplate(prodDataSource);}@Beanpublic JdbcOperations devJdbcOperations(@Qualifier("devDataSource") DataSource devDataSource) { return new JdbcTemplate(devDataSource);}
使用
- 直接注入
JdbcOperations
即可
@Autowired private JdbcOperations devJdbcOperations; @Autowired private JdbcOperations prodJdbcOperations;
事务配置
开启事务管理功能
在项目入口类,添加以下注解开启事务管理功能。
@EnableTransactionManagement
配置事务管理器
@Beanpublic PlatformTransactionManager prodTransactionManager(@Qualifier("prodDataSource") DataSource prodDataSource) { return new DataSourceTransactionManager(prodDataSource);}@Beanpublic 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.html
1 0
- Spring Boot多数据源及其事务管理配置
- spring boot Mybatis多数据源配置
- spring boot多数据源配置
- spring boot 多数据源配置
- spring boot + mybatis 多数据源配置
- Spring Boot多数据源配置
- Spring boot配置多数据源
- spring多数据源的配置(分布式事务管理)
- Spring多数据源配置及事务管理(待续)
- Spring Boot + Spring Data JPA项目配置多数据源
- spring-boot 使用 spring-data-jpa多数据源配置
- Spring Boot,Spring Data JPA多数据源支持配置
- Spring Boot 多数据源
- Spring Boot 多数据源
- Spring Boot多数据源
- Spring Boot 多数据源
- Spring Boot 多数据源
- Spring Boot 多数据源
- Xcode工程项目改名的操作步骤
- Datebase数据库
- Google Code Jam 2017 资格赛
- Oracle学习笔记(一)
- 常规功能和模块自定义系统—061商业智能(BI)的视频及演示地址
- Spring Boot多数据源及其事务管理配置
- CentOS7.0安装Nginx 1.7.4以及相关命令
- C++
- js中 javascript:void(0) 用法详解
- Java中重载与重写的区别
- JavaScript:响应式——rem
- Java-字符串创建与存储的机制
- $.ajax()
- String类型详解