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(三)配置双数据源的更多相关文章

  1. spring项目配置双数据源读写分离

    我们最早做新项目的时候一直想做数据库的读写分离与主从同步,由于一些原因一直没有去做这个事情,这次我们需要配置双数据源的起因是因为我们做了一个新项目用了另一个数据库,需要把这个数据库的数据显示到原来的后 ...

  2. spring boot 配置双数据源mysql、sqlServer

    背景:原来一直都是使用mysql数据库,在application.properties 中配置数据库信息 spring.datasource.url=jdbc:mysql://xxxx/test sp ...

  3. SpringBoot+MyBatis配置多数据源

    SpringBoot 可以支持多数据源,这是一个非常值得学习的功能,但是从现在主流的微服务的架构模式中,每个应用都具有唯一且准确的功能,多数据源的需求很难用到,考虑到实际情况远远比理论复杂的多,这里还 ...

  4. spring+mybatis 配置双数据源

    配置好后,发现网上已经做好的了, 不过,跟我的稍有不同, 我这里再拿出来现个丑: properties 文件自不必说,关键是这里的xml: <?xml version="1.0&quo ...

  5. springboot配置双数据源 MySQL和SqlServer

    1. pom文件的驱动jar包加上去, compile 'com.microsoft.sqlserver:mssql-jdbc:6.2.2.jre8' 2. application.yml sprin ...

  6. springboot + mybatis配置多数据源示例

    转:http://www.jb51.net/article/107223.htm 在实际开发中,我们一个项目可能会用到多个数据库,通常一个数据库对应一个数据源. 代码结构: 简要原理: 1)Datab ...

  7. Java开发学习(三十六)----SpringBoot三种配置文件解析

    一. 配置文件格式 我们现在启动服务器默认的端口号是 8080,访问路径可以书写为 http://localhost:8080/books/1 在线上环境我们还是希望将端口号改为 80,这样在访问的时 ...

  8. SpringMVC配置双数据源,一个java项目同时连接两个数据库

    数据源在配置文件中的配置 请点击--->   java架构师项目实战,高并发集群分布式,大数据高可用,视频教程 <pre name="code" class=" ...

  9. spring 配置双数据源并读写分离

    摘自 开源项目Ibase4j    关键思想在于AbstractRoutingSource 类 还有方法名称和切入点去控制使用哪个数据源    1.首先在配置文件配置多个数据源 并且交给继承自spri ...

随机推荐

  1. connection reset 分析解决(转载)

    文章转自:https://my.oschina.net/xionghui/blog/508758;记录下来以便以后复习查阅; 在使用HttpClient调用后台resetful服务时,“Connect ...

  2. pytest的fixture和conftest

    解决问题:用例1需要先登录,用例2不需要登录,用例3需要先登录.很显然这就无法用setup和teardown来实现了,这个时候就可以自定义测试用例的预置条件,比setup灵活很多. 1.fixture ...

  3. Java学习笔记28(IO字节流)

    IO定义: 写:Output操作:将内存上的数据持久化 到设备上,这个动作称为输出: 读:Input操作:把硬盘上的东西读取到内存,这个动作称为输入:              这两种操作称为IO流 ...

  4. 【Python】多进程1

    1.    进程定义: (1) 进程是一个实体.每个进程都有他自己的地址空间,一般包括文本区域.数据区域和堆栈.进程是线程的容器. (2) 进程是一个“执行中的程序” 2.    进程的特征: (1) ...

  5. grep命令相关用法

    grep命令相关参数: -i:忽略大小写 --color:高亮显示匹配到的信息 -v:反向查找,没匹配到的行显示出来 -o:只显示被模式匹配到的串本身 正则表达式: .*:任意长度的任意字符,贪婪模式 ...

  6. 12.double的int方

    给定一个double类型的浮点数base和int类型的整数exponent.求base的exponent次方. 不要用Math.pow(double,double)哟.效率极其低下,比连成慢好多: 题 ...

  7. cat命令合并多个txt文件

    cat是concatenate的缩写,意为串联,之前经常看到别人在用cat命令,没有细究 cat命令两个常用的用法是: cat file.txt能够将txt中的内容显示出来 cat file1.txt ...

  8. 实验吧—Web——WP之 上传绕过

    我们先上传一个png文件,发现他说必须上传后缀名为PHP的文件才可以,那么,我们尝试一下,PHP文件 但是他又说不被允许的文件类型 在上传绕过里最有名的的就是00截断,那么我们就先要抓包 在这里我们需 ...

  9. Hadoop权威指南

    初识Hadoop Hadoop与其它系统比较 数据库的劣势:磁盘寻址性能低发展慢 数据库索引? MapReduce适合一次写入,多次读取的应用,关系型数据库适合持续更新的数据集 Hadoop在处理数据 ...

  10. 《DSP using MATLAB》Problem 6.7

    代码: %% ++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++ %% Output In ...