六、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 ...
随机推荐
- python自学第5天,集合,文件读写
#!/usr/bin/env python #-*- coding:utf-8 -*- # Author:Hunter Yi s={1,1,1,2,3,4,5} print(s) #集合,去重 #关系 ...
- array_reverse()函数
$a=array(1,2,4,5,6); print_r(array_reverse($a)); 结果:Array ( [0] => 6 ...
- python day03--字符串
一.字符串 1.索引 s1 = "python最牛B" S1[0]第0个,从零开始算 s1[8]“B” 2.切片 语法: str[start: end]规则: 顾头不顾腚, 从st ...
- php实现弱语言底层原理分析(转)
php中弱语言类型的底层实现 PHP是弱语言类型,主要分为三类: 1.标量类型:integer.string.float.boolean 2.复合类型:array.object 3.特殊类型:reso ...
- 【计算机视觉】KCF算法
code opencv3.3.1-contrib ---- TrackerKCF.cpp opencv如何更新目标区域的过程: // calculate filter response if(par ...
- 【c++基础】字符数组和string相互转换
字符数组转化成string类型char ch [] = "ABCDEFG";string str(ch);//也可string str = ch;或者char ch [] = &q ...
- git命令收集(记得持续更新)
这里收集了一些常用的git命令: git remote add origin git@192.168.1.128:sabo/ycdd-server.git git push -u origin mas ...
- HTML5的一些知识点
1.新增很多api,比如获取用户的地理位置的window.navigator.geoloaction,history,audio,video,canvas 2.websocket;websocket是 ...
- MyBatis sql语句使用总结
MyBatis中Like语句使用总结 oracle数据库: SELECT * FROM user WHERE name like CONCAT('%',#{name},'%') 或 : SELECT ...
- 重写ajax方法实现请求session过期时跳转登录页面
jQuery(function($){ var _ajax=$.ajax; // 备份jquery的ajax方法 $.ajax=function(opt){ var _success = opt &a ...