Spring Data JPA 从入门到精通~如何配置多数据源

如何配置多数据源

在 application.properties 中定义两个 DataSource

定义两个 DataSource 用来读取 application.properties 中的不同配置。如下例子中,主数据源配置为 spring.datasource.one 开头的配置,第二数据源配置为 spring.datasource.two 开头的配置。

//这是默认配置,我们做一下对比
spring.datasource.url=db1
spring.datasource.username=db1_username
spring.datasource.password=db1_password
//# Druid 数据源配置,继承spring.datasource.* 配置,相同则覆盖
...
spring.datasource.druid.initial-size=5
spring.datasource.druid.max-active=5
...//#Druid 数据源 1 配置,继承spring.datasource.druid.* 配置,相同则覆盖
//#db1的配置会上面的配置
...
spring.datasource.druid.one.url=db1
spring.datasource.druid.one.username=db1_username
spring.datasource.druid.one.password=db1_password
spring.datasource.druid.one.max-active=10
spring.datasource.druid.one.max-wait=10000
...
//# Druid 数据源 2 配置,继承spring.datasource.druid.* 配置,相同则覆盖
...
spring.datasource.druid.two.url=db2
spring.datasource.druid.two.username=db2_username
spring.datasource.druid.two.password=db2_password
spring.datasource.druid.two.max-active=20
spring.datasource.druid.two.max-wait=20000
...

定义两个 DataSourceConfigJava 类

两个 DataSourceConfig 类内容如下:

@Configuration
@EnableTransactionManagement
@EnableJpaRepositories(entityManagerFactoryRef="entityManagerFactoryOne",transactionManagerRef="transactionManagerOne",basePackages= { "com.jackzhang.example.one" }) //设置Repository所在位置
@EnableConfigurationProperties(JpaProperties.class)
public class DataSourceOneConfig {/*** 配置数据源1*/@Primary@Bean(name = "dataSourceOne")@ConfigurationProperties("spring.datasource.druid.one")public DataSource dataSourceOne(){return DruidDataSourceBuilder.create().build();}@Autowired@Qualifier("dataSourceOne")private DataSource oneDataSource;@Primary@Bean(name = "entityManagerOne")public EntityManager entityManager(EntityManagerFactoryBuilder builder) {return entityManagerFactoryOne(builder).getObject().createEntityManager();}@Primary@Bean(name = "entityManagerFactoryOne")public LocalContainerEntityManagerFactoryBean entityManagerFactoryOne (EntityManagerFactoryBuilder builder) {return builder.dataSource(oneDataSource).properties(getVendorProperties(oneDataSource)).packages("com.jackzhang.example.one") //设置实体类所在位置.persistenceUnit("onePersistenceUnit").build();}@Autowiredprivate JpaProperties jpaProperties;private Map<String, String> getVendorProperties(DataSource dataSource) {return jpaProperties.getHibernateProperties(dataSource);}@Primary@Bean(name = "transactionManagerOne")public PlatformTransactionManager transactionManagerOne(EntityManagerFactoryBuilder builder) {return new JpaTransactionManager(entityManagerFactoryOne(builder).getObject());}
}
@Configuration
@EnableTransactionManagement
@EnableJpaRepositories(entityManagerFactoryRef="entityManagerFactoryTwo",transactionManagerRef="transactionManagerTwo",basePackages= { "com.jackzhang.example.two" }) //设置Repository所在位置
@EnableConfigurationProperties(JpaProperties.class)
public class DataSourceTwoConfig {/*** 配置数据源2*/@Primary@Bean(name = "dataSourceTwo")@ConfigurationProperties("spring.datasource.druid.two")public DataSource dataSourceTwo(){return DruidDataSourceBuilder.create().build();}@Autowired@Qualifier("dataSourceTwo")private DataSource twoDataSource;@Primary@Bean(name = "entityManagerTwo")public EntityManager entityManager(EntityManagerFactoryBuilder builder) {return entityManagerFactoryTwo(builder).getObject().createEntityManager();}@Primary@Bean(name = "entityManagerFactoryTwo")public LocalContainerEntityManagerFactoryBean entityManagerFactoryTwo (EntityManagerFactoryBuilder builder) {return builder.dataSource(twoDataSource).properties(getVendorProperties(twoDataSource)).packages("com.jackzhang.example.two") //设置实体类所在位置.persistenceUnit("twoPersistenceUnit").build();}@Autowiredprivate JpaProperties jpaProperties;private Map<String, String> getVendorProperties(DataSource dataSource) {return jpaProperties.getHibernateProperties(dataSource);}@Primary@Bean(name = "transactionManagerTwo")public PlatformTransactionManager transactionManagerTwo(EntityManagerFactoryBuilder builder) {return new JpaTransactionManager(entityManagerFactoryTwo(builder).getObject());}
}

我们发现 DataSourceTwoConfig、DataSourceOneConfig 内容基本一样,思路就是管理两套 datasource,从而带来了两套 transactionManager,分别在这两个 package 下创建各自的实体和数据访问接口即可。当然了也可以通过 @Transactional(rollbackFor = Exception.class, transactionManager= "transactionManagerOne") 来手动选择哪个数据源。

多数据源的场景

随着微服务的推行,其实很少有多数据源的场景的,作者不建议出现多数据源,当出现的时候就要想想,模块划分的是否合理,是否可以通过服务去解决,但不排除 Job 等。

本文来自互联网用户投稿,该文观点仅代表作者本人,不代表本站立场。本站仅提供信息存储空间服务,不拥有所有权,不承担相关法律责任。如若转载,请注明出处:http://www.mzph.cn/news/496279.shtml

如若内容造成侵权/违法违规/事实不符,请联系多彩编程网进行投诉反馈email:809451989@qq.com,一经查实,立即删除!

相关文章

NASA投资有远景技术,有望改变未来人类和机器人的勘探任务

来源&#xff1a; 机器人创新生态据NASA官网报道&#xff0c;美国宇航局(NASA)正在投资有远见的技术概念&#xff0c;包括流星撞击探测、太空望远镜群以及细小轨道碎片测绘技术&#xff0c;这些技术将来可能被用于未来的太空探索任务中。美国宇航局已经选出25个还处于早期的技术…

feedback.php,feedback.php

Feedback | Training Labif (!isset($_SESSION[username])) {header(Location: index.php#loginSub);}if($_GET){//查询require_once DAO.php;$dbnew DB();$data[fb_id] $_GET[feedbackid];$judge[fb_id] ;list($conSql, $mapConData) $db->FDFields($data,"",…

2008中国软件企业出口(外包)20强

2008中国软件企业出口20强 1 东软集团股份有限公司 2 大连华信计算机技术股份有限公司 3 海辉软件(国际)集团 4 浙大网新科技股份有限公司 5 中软国际有限公司 6 北大方正集团有限公司 7 上海中和软件有限公司 8 日电卓越软件科技(北京)有限公司 9 上海海隆软件股份有限公司 10…

人工智能如何影响社会经济:关于近期文献的一个综述

作者&#xff1a;陈永伟 文章来源&#xff1a;经济学原理 相比于之前的历次技术进步&#xff0c;“人工智能革命”所引发的冲击更为巨大&#xff0c;其对经济学造成的影响也将更为广泛和深远。人工智能技术的突飞猛进&#xff0c;对经济社会的各个领域都产生了重大影响&#…

oracle近似查找,距离内的Oracle空间搜索

对于mySQL距离搜索,你有很好的参考.忘记Oracle Spatial的东西.代码太多,复杂性太大,没有足够的增值.这是一个可以解决问题的查询.这使用法定里程的距离.编辑这修复了mdarwin提到的错误,如果你试图将它用于北极或南极的位置,则以划分检查为代价.SELECT id, city, LATITUDE, LONG…

Spring Data JPA 从入门到精通~Naming命名策略详解及其实践

Naming 命名策略详解及其实践 用 JPA 离不开 Entity 实体&#xff0c;我都知道实体里面有字段映射&#xff0c;而字段映射的方法有两种&#xff1a; 显式命名&#xff1a;在映射配置时&#xff0c;设置的数据库表名、列名等&#xff0c;就是进行显式命名&#xff0c;即通过 C…

C 和 C++ 字符串格式化

--------------------------------------------------------------------------------- gcc中格式化输出函数的研究&#xff1a;http://blog.csdn.net/dai_xiangjun/article/details/41356723 C语言格式化输出小结&#xff1a;http://blog.51cto.com/happyliu/1621709 代码如…

转载(四).Net Framework中的委托与事件

尽管 &#xff08;委托、事件与Observer设计模式 &#xff09;中的范例很好地完成了我们想要完成的工作&#xff0c;但是我们不仅疑惑&#xff1a;为什么.Net Framework 中的事件模型和上面的不同&#xff1f;为什么有很多的EventArgs参数&#xff1f; 在回答上面的问题之前&am…

激光雷达:从光电技术角度看自动驾驶

来源&#xff1a; 传感器技术激光雷达和与之竞争的传感器技术&#xff08;相机、雷达和超声波&#xff09;加强了对传感器融合的需要&#xff0c;也对认真谨慎地选择光电探测器、光源和MEMS振镜提出了更高的要求。传感器技术、成像、雷达、光探测技术及测距技术&#xff08;激光…

Spring Data JPA 从入门到精通~定义查询方法的配置方法

定义查询方法的配置方法 由于 Spring JPA Repository 的实现原理是采用动态代理的机制&#xff0c;所以我们介绍两种定义查询方法&#xff0c;从方法名称中可以指定特定用于存储的查询和更新&#xff0c;或通过使用 Query 手动定义的查询&#xff0c;取决于实际对数据的操作&a…

socket的长连接、短连接、半包、粘包与分包

socket的半包&#xff0c;粘包与分包的问题和处理代码&#xff1a;http://blog.csdn.net/qq_16112417/article/details/50392463 知乎关于长连接和短连接&#xff1a;https://www.zhihu.com/search?typecontent&q长连接%20短连接 TCP网络通讯如何解决分包粘包问题&#…

在Windows2003server上安装msn9.0以上版本的解决办法

方法一&#xff1a; 最近windows 强制升级了msn 9的版本。导致我在windows2003下的msn又一次需要剥离出msi文件才能安装了。在网上逛了一圈发现了如下方法&#xff0c;这里分享下&#xff0c;同时&#xff0c;也感谢作者的详细步骤。 2003SERVER版安装MSN 9.0&#xff08;版本2…

oracle exec编译失效,编译oracle失效的函数、存储过程、视图等

进行oracle开发时常常为不时失效的存储过程&#xff0c;函数等苦恼&#xff0c;于是下决心解决这个问题&#xff0c;东查西找&#xff0c;找到一个好东东&#xff0c;在基础上又修改了一下,问题终于被我解决了。1。建立一个存储过程CREATE OR REPLACE PROCEDURE TIMER_AUTO_REC…

2018年中国人工智能行业研究报告|附下载

来源&#xff1a;网络大数据、艾瑞咨询广义人工智能指通过计算机实现人的头脑思维所产生的效果&#xff0c;是对能够从环境中获取感知并执行行动的智能体的描述和构建;相对狭义的人工智能包括人工智能产业(包含技术、算法、应用等多方面的价值体系)、人工智能技术(包括凡是使用…

浅谈基于TCP和UDP的协议设计

From&#xff1a;http://blog.sina.com.cn/s/blog_48d4cf2d0101859x.html 一个基于TCP/WebSockets的超级精简的长连接消息协议&#xff1a;https://studygolang.com/articles/10506 github 上 一个简单的消息协议&#xff1a;https://github.com/acrazing/stmp google prot…

Spring Data JPA 从入门到精通~方法的查询策略设置

方法的查询策略设置 通过下面的命令来配置方法的查询策略&#xff1a; EnableJpaRepositories(queryLookupStrategy QueryLookupStrategy.Key.CREATE_IF_NOT_FOUND) 其中&#xff0c;QueryLookupStrategy.Key 的值一共就三个&#xff1a; Create&#xff1a;直接根据方法名…

IE6下PNG图片透明效果(PNG图片做背景也可以)

懒人萱在这里保证发的文章都是高质量的经过测试的JS代码&#xff0c;而且IE6、IE7和火狐都兼容的&#xff0c;希望大家多多关注我的帖子&#xff0c;我会把我的经验都共享出来哦&#xff01;  懒人萱在寻找PNG图片透明效果的JS特效代码的时候&#xff0c;发现大部分的效果只能…

oracle数据块调用存储过程,VC调用存储过程的通用方法(ORACLE篇)

先对上一篇调用SQLServer的存储过程作一点补充&#xff0c;就是如果存储过程里有Insert,update,delete等操作&#xff0c;最后返回结果集&#xff0c;按示例代码有可能得不到数据&#xff0c;因为返回的数据有可能不在第一个结果集&#xff0c;需要进行遍历&#xff1a;long ln…

不用地图如何导航?DeepMind提出新型双路径强化学习「智能体」架构

来源&#xff1a;deepmind、arXiv作者&#xff1a;Piotr Mirowski、Matthew Koichi Grimes、Mateusz Malinowski、Karl Moritz Hermann、Keith Anderson、Denis Teplyashin、Karen Simonyan、Koray Kavukcuoglu、Andrew Zisserman、Raia Hadsell「雷克世界」编译&#xff1a;嗯…

C 和 C++ 宏 详解

From&#xff1a;https://www.cnblogs.com/njczy2010/p/5773061.html C中的预编译宏详解&#xff1a;http://www.cppblog.com/bellgrade/archive/2010/03/18/110030.html C语言的宏总结&#xff1a;http://blog.csdn.net/pirlck/article/details/51254590 C 语言中的 宏定义…