六、springboot(三)配置双数据源
1、目录结构

2.jdbc.properties配置
#db houge spring.datasource.houge.jdbc-url=jdbc:oracle:thin:@192.168.0.120::ORCL spring.datasource.houge.username=houge spring.datasource.houge.password=monkey spring.datasource.houge.driver-class-name=oracle.jdbc.driver.OracleDriver spring.datasource.houge.initial-size= spring.datasource.houge.min-idle= spring.datasource.houge.max-active= #db gkh spring.datasource.gkh.jdbc-url=jdbc:oracle:thin:@192.168.0.115::ORCL spring.datasource.gkh.username=gkh spring.datasource.gkh.password= spring.datasource.gkh.driver-class-name=oracle.jdbc.driver.OracleDriver spring.datasource.gkh.initial-size= spring.datasource.gkh.min-idle= spring.datasource.gkh.max-active=
3、注解式数据源配置DataSourceConfig
@Configuration
@PropertySource("classpath:config/jdbc.properties")
public class DataSourceConfig {
@Primary
@Bean(name = "dataSourceHouge")
@ConfigurationProperties(prefix = "spring.datasource.houge")
public DataSource dataSourceHouge() {
return DataSourceBuilder.create().build();
}
@Bean(name = "dataSourceGkh")
@ConfigurationProperties(prefix = "spring.datasource.gkh")
public DataSource dataSourceGkh() {
return DataSourceBuilder.create().build();
}
}
4、houge数据库配置
@Configuration
@EnableTransactionManagement
@EnableJpaRepositories(
entityManagerFactoryRef = "entityManagerFactoryHouge",
transactionManagerRef = "transactionManagerHouge",
basePackages = {"com.lofty.springboot.repository.houge" })
public class HougeDataSource {
@Autowired
@Qualifier("dataSourceHouge")
private DataSource dataSourceHouge;
@Primary
@Bean(name = "entityManagerFactoryHouge")
public LocalContainerEntityManagerFactoryBean entityManagerFactoryHouge(EntityManagerFactoryBuilder builder) {
LocalContainerEntityManagerFactoryBean em = builder.dataSource(dataSourceHouge)
.packages("com.lofty.springboot.domain.houge")
.persistenceUnit("hougePersistenceUnit").build();
return em;
}
@Primary
@Bean(name = "transactionManagerHouge")
PlatformTransactionManager transactionManagerHouge(EntityManagerFactoryBuilder builder) {
return new JpaTransactionManager(entityManagerFactoryHouge(builder).getObject());
}
}
5、gkh数据库配置
@Configuration
@EnableTransactionManagement
@EnableJpaRepositories(
entityManagerFactoryRef = "entityManagerFactoryGkh",
transactionManagerRef = "transactionManagerGkh",
basePackages = {"com.lofty.springboot.repository.gkh" })
public class GkhDataSource {
@Autowired
@Qualifier("dataSourceGkh")
private DataSource dataSourceGkh;
@Bean(name = "entityManagerFactoryGkh")
public LocalContainerEntityManagerFactoryBean entityManagerFactoryGkh(EntityManagerFactoryBuilder builder) {
LocalContainerEntityManagerFactoryBean em = builder.dataSource(dataSourceGkh)
.packages("com.lofty.springboot.domain.gkh")
.persistenceUnit("gkhPersistenceUnit").build();
return em;
}
@Bean(name = "transactionManagerGkh")
PlatformTransactionManager transactionManagerGkh(EntityManagerFactoryBuilder builder) {
return new JpaTransactionManager(entityManagerFactoryGkh(builder).getObject());
}
}
6、启动测试
六、springboot(三)配置双数据源的更多相关文章
- spring项目配置双数据源读写分离
我们最早做新项目的时候一直想做数据库的读写分离与主从同步,由于一些原因一直没有去做这个事情,这次我们需要配置双数据源的起因是因为我们做了一个新项目用了另一个数据库,需要把这个数据库的数据显示到原来的后 ...
- spring boot 配置双数据源mysql、sqlServer
背景:原来一直都是使用mysql数据库,在application.properties 中配置数据库信息 spring.datasource.url=jdbc:mysql://xxxx/test sp ...
- SpringBoot+MyBatis配置多数据源
SpringBoot 可以支持多数据源,这是一个非常值得学习的功能,但是从现在主流的微服务的架构模式中,每个应用都具有唯一且准确的功能,多数据源的需求很难用到,考虑到实际情况远远比理论复杂的多,这里还 ...
- spring+mybatis 配置双数据源
配置好后,发现网上已经做好的了, 不过,跟我的稍有不同, 我这里再拿出来现个丑: properties 文件自不必说,关键是这里的xml: <?xml version="1.0&quo ...
- springboot配置双数据源 MySQL和SqlServer
1. pom文件的驱动jar包加上去, compile 'com.microsoft.sqlserver:mssql-jdbc:6.2.2.jre8' 2. application.yml sprin ...
- springboot + mybatis配置多数据源示例
转:http://www.jb51.net/article/107223.htm 在实际开发中,我们一个项目可能会用到多个数据库,通常一个数据库对应一个数据源. 代码结构: 简要原理: 1)Datab ...
- Java开发学习(三十六)----SpringBoot三种配置文件解析
一. 配置文件格式 我们现在启动服务器默认的端口号是 8080,访问路径可以书写为 http://localhost:8080/books/1 在线上环境我们还是希望将端口号改为 80,这样在访问的时 ...
- SpringMVC配置双数据源,一个java项目同时连接两个数据库
数据源在配置文件中的配置 请点击---> java架构师项目实战,高并发集群分布式,大数据高可用,视频教程 <pre name="code" class=" ...
- spring 配置双数据源并读写分离
摘自 开源项目Ibase4j 关键思想在于AbstractRoutingSource 类 还有方法名称和切入点去控制使用哪个数据源 1.首先在配置文件配置多个数据源 并且交给继承自spri ...
随机推荐
- vue 编译原理 简介
来源 tinycompile 关于vue的内部原理其实有很多个重要的部分,变化侦测,模板编译,virtualDOM,整体运行流程等. 之前写过一篇<深入浅出 - vue变化侦测原理> 讲了 ...
- centos7设置默认的内核启动
centos内核启动时会有3个选项,只有一个可以正常登陆到图形界面的桌面: 下面是设置默认内核的顺序: centos的内核文件在/boot/grub2目录下 1.如果想要修改以上三项的显示顺序,只需要 ...
- setcookie
cookie 中值的部分在发送的时候会被自动用 urlencode 编码并在接收到的时候被自动解码并把值赋给与自己同名的 cookie 变量 首先声明,浏览的Cookie操作都是通过HTTP Head ...
- 集合(ArrayList)简述
ArrayList创建变量的步骤 1.导入包java.util.ArrayList; 2.创建引用类型的变量 数据类型<集合存储的数据类型> 变量名=new 数据类型<集合存储的数据 ...
- sql order by 结合case when then
SELECT * FROM datav.a_current_per_entry_01 WHERE intime = (SELECT MAX(intime) FROM a_current_per_ent ...
- Django is not importable in this environment
1.由于把venv给忽略了,所以显示找不到django. 2.在.gitignore中加入了 venv\会导致,在此git目录下,用pycharm 创建的项目会自动在 file types中的地方加 ...
- extjs技术
转载:http://www.cnblogs.com/willick/p/3168809.html 转载 :http://www.cnblogs.com/youring2/archive/2013/08 ...
- python 基础 内置函数 和lambda表达式
1.把任意数值转化为字符串有两种方法. (1)str()用于将数值转化为易于人读的形式.print(str("我是中国人"))>>>我是中国人 (2)repr() ...
- SQLAlchemy中表结构的一对多
from flask import Flask from flask_sqlalchemy import SQLAlchemy import pymysql pymysql.install_as_My ...
- Notepad2、Sublime_text带图标的右键快捷打开方式
实现的效果:选中文本文件右键鼠标之后,按x键即可用notepad2快速打开文件,按3则可以用Sublime_text打开文件. 具体过程:根据各自需求,将下面的注册表信息,保存到本地新建的文本文件中, ...