全网整合营销服务商

电脑端+手机端+微信端=数据同步管理

免费咨询热线:400-708-3566

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
public class JdbcConfig {

}

配置数据源

给其中一个数据源加上@Primary。因为在Spring Boot Jdbc的自动配置过程中,会对于开发者透明地使用dataSource进行一些相关配置,所以当有两个Datasource实现类时,Spring Boot将无法确定使用哪一个。

当我们不为@Bean指定名字时,Spring会默认使用方法名作为Bean的名字,所以下面两个数据源的名字分别为prodDataSourcedevDataSource

@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。

@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;

事务配置

开启事务管理功能

在项目入口类,添加注解开启事务管理功能。

@EnableTransactionManagement

配置事务管理器

@Bean
public PlatformTransactionManager prodTransactionManager(DataSource prodDataSource) {
 return new DataSourceTransactionManager(prodDataSource);
}

@Bean
public PlatformTransactionManager devTransactionManager(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

以上就是本文的全部内容,希望对大家的学习有所帮助,也希望大家多多支持。


# springboot 多数据源  # spring boot 数据源  # spring boot 事务配置  # SpringBoot使用JTA实现对多数据源的事务管理  # SpringBoot2使用JTA组件实现基于JdbcTemplate多数据源事务管理(亲测好用)  # springboot-jta-atomikos多数据源事务管理实现  # SpringBoot2整合JTA组件实现多数据源事务管理  # 多数据源如何实现事务管理  # 在此  # 不需要  # 配置文件  # 相匹配  # 也不  # 还可以  # 有很多  # 只需  # 为其  # 分别为  # 不为  # 当我们  # 管理器  # 其中一个  # 准备工作  # 会将  # 需要用  # 请参考  # 大家多多  # 先给 


相关文章: 如何在建站之星绑定自定义域名?  如何用搬瓦工VPS快速搭建个人网站?  宝盒自助建站智能生成技巧:SEO优化与关键词设置指南  实例解析angularjs的filter过滤器  C#如何使用XPathNavigator高效查询XML  建站之星安装后界面空白如何解决?  ,在苏州找工作,上哪个网站比较好?  如何优化Golang Web性能_Golang HTTP服务器性能提升方法  如何配置WinSCP新建站点的密钥验证步骤?  青浦网站制作公司有哪些,苹果官网发货地是哪里?  黑客入侵网站服务器的常见手法有哪些?  简历在线制作网站免费,免费下载个人简历的网站是哪些?  北京网站制作网页,网站升级改版需要多久?  免费网站制作appp,免费制作app哪个平台好?  专业企业网站设计制作公司,如何理解商贸企业的统一配送和分销网络建设?  公司门户网站制作公司有哪些,怎样使用wordpress制作一个企业网站?  建站之星后台管理如何实现高效配置?  建站主机选择指南:服务器配置与SEO优化实战技巧  建站之星如何配置系统实现高效建站?  如何用好域名打造高点击率的自主建站?  官网网站制作腾讯审核要多久,联想路由器newifi官网  如何登录建站主机?访问步骤全解析  宝塔建站无法访问?如何排查配置与端口问题?  如何快速搭建高效服务器建站系统?  如何通过商城免费建站系统源码自定义网站主题?  建站主机核心功能解析:服务器选择与网站搭建流程指南  在线制作视频网站免费,都有哪些好的动漫网站?  ,购物网站怎么盈利呢?  利用JavaScript实现拖拽改变元素大小  在线制作视频的网站有哪些,电脑如何制作视频短片?  如何制作一个表白网站视频,关于勇敢表白的小标题?  如何在Golang中实现微服务服务拆分_Golang微服务拆分与接口管理方法  建站10G流量真的够用吗?如何应对访问高峰?  如何设置并定期更换建站之星安全管理员密码?  制作网站的模板软件,网站怎么建设?  宝塔面板如何快速创建新站点?  高防服务器:AI智能防御DDoS攻击与数据安全保障  如何快速登录WAP自助建站平台?  全景视频制作网站有哪些,全景图怎么做成网页?  微信推文制作网站有哪些,怎么做微信推文,急?  关于BootStrap modal 在IOS9中不能弹出的解决方法(IOS 9 bootstrap modal ios 9 noticework)  网站制作外包价格怎么算,招聘网站上写的“外包”是什么意思?  c++如何打印函数堆栈信息_c++ backtrace函数与符号名解析【方法】  学校建站服务器如何选型才能满足性能需求?  哪家制作企业网站好,开办像阿里巴巴那样的网络公司和网站要怎么做?  宝塔面板创建网站无法访问?如何快速排查修复?  如何在万网主机上快速搭建网站?  标准网站视频模板制作软件,现在有哪个网站的视频编辑素材最齐全的,背景音乐、音效等?  长春网站建设制作公司,长春的网络公司怎么样主要是能做网站的?  已有域名和空间如何搭建网站? 

您的项目需求

*请认真填写需求信息,我们会在24小时内与您取得联系。