SpringBoot+Jpa项目配置双数据源的实现

作者:爱唱歌的胖虎 时间:2022-11-01 14:05:04 

目录
  • 引言

  • 配置yml文件

  • 创建数据源配置类

  • 为每个数据库创建配置类

引言

今天为大家带来一些非常有用的实战技巧,比如在我们需要对两个数据库进行操作的时候而哦我们通常用的只是单数据库查询,这就触及到知识盲点了,那么废话不多说上代码!

配置yml文件


server:
 port: 8080
spring:
 profiles:
   active: dev
 jackson:
   time-zone: GMT+8  

# 这里是我们的数据库配置地方    
datasource:
   data1:  #这里是数据库一
     driverClassName: com.mysql.cj.jdbc.Driver
     url: jdbc:mysql://192.168.0.77:3306/test1?characterEncoding=UTF-8&serverTimezone=Asia/Shanghai&autoReconnect=true&failOverReadOnly=false&rewriteBatchedStatements=true
     username: root
     password: 123
     type: com.alibaba.druid.pool.DruidDataSource

data2:  #这里是数据库二
     driverClassName: com.mysql.cj.jdbc.Driver
     url: jdbc:mysql://192.168.0.88:3306/test2?characterEncoding=UTF-8&serverTimezone=Asia/Shanghai&autoReconnect=true&failOverReadOnly=false&rewriteBatchedStatements=true
     username: root
     password: 123
     type: com.alibaba.druid.pool.DruidDataSource

当然到这里肯定是没有结束的,需要配置一些参数,否则启动会报错

创建数据源配置类

我们创建一个数据源的类,我们就给他取名为DataSourceConfig(这个名字自定义),在项目下创建一个包,方便管理

SpringBoot+Jpa项目配置双数据源的实现


package com.eman.cdn.common.dataSource;

import org.springframework.beans.factory.annotation.Qualifier;
import org.springframework.boot.autoconfigure.ImportAutoConfiguration;
import org.springframework.boot.autoconfigure.jdbc.DataSourceProperties;
import org.springframework.boot.context.properties.ConfigurationProperties;
import org.springframework.context.annotation.Bean;
import org.springframework.context.annotation.Configuration;
import org.springframework.context.annotation.Primary;

import javax.sql.DataSource;

/**
* @author https://blog.csdn.net/weixin_42782429?spm=1000.2115.3001.5343
* @date 2021/12/21 11:35
* <p>
* description 数据源配置
*/
@Configuration
public class DataSourceConfig {

# 这里是我们在yml文件配置的位置
   private final static String DB_TEST1 = "spring.datasource.test1";
   private final static String DB_TEST2= "spring.datasource.test1";

# 这个Bean名字子自定义只要不是重复的Bean名字就行了
   @Bean(name = "test1Properties")
   @Qualifier("test1Properties")
   @Primary
   @ConfigurationProperties(DB_TEST1)
   public DataSourceProperties test1Properties() {
       return new DataSourceProperties();
   }

@Bean(name = "test1DataSource")
   @Qualifier("test1DataSource")
   @Primary
   @ConfigurationProperties(prefix = DB_TEST1)
   public DataSource test1DataSource() {
       return test1Properties().initializeDataSourceBuilder().build();
   }

@Bean(name = "test2Properties")
   @Qualifier("test2Properties")
   @ConfigurationProperties(DB_TEST2)
   public DataSourceProperties test2Properties() {
       return new DataSourceProperties();
   }

@Bean(name = "test2DataSource")
   @Qualifier("test2DataSource")
   @ConfigurationProperties(prefix = DB_ANALYSIS)
   public DataSource test2DataSource() {
       return test2Properties().initializeDataSourceBuilder().build();
   }
}

为每个数据库创建配置类

由于需要用到Mybaitis-plus所以你得先导入Mybaitis-Plus的依赖


<!--mybatis-plus-->
       <dependency>
           <groupId>com.baomidou</groupId>
           <artifactId>mybatis-plus-boot-starter</artifactId>
           <version>3.1.0</version>
       </dependency>


package com.eman.xx.xxx.xx;

import com.baomidou.mybatisplus.extension.spring.MybatisSqlSessionFactoryBean;
import org.apache.ibatis.session.SqlSessionFactory;
import org.mybatis.spring.SqlSessionTemplate;
import org.mybatis.spring.annotation.MapperScan;
import org.springframework.beans.factory.annotation.Autowired;
import org.springframework.beans.factory.annotation.Qualifier;
import org.springframework.boot.autoconfigure.orm.jpa.HibernateProperties;
import org.springframework.boot.autoconfigure.orm.jpa.HibernateSettings;
import org.springframework.boot.autoconfigure.orm.jpa.JpaProperties;
import org.springframework.boot.orm.jpa.EntityManagerFactoryBuilder;
import org.springframework.context.annotation.Bean;
import org.springframework.context.annotation.Configuration;
import org.springframework.core.io.support.PathMatchingResourcePatternResolver;
import org.springframework.data.jpa.repository.config.EnableJpaRepositories;
import org.springframework.orm.jpa.JpaTransactionManager;
import org.springframework.orm.jpa.LocalContainerEntityManagerFactoryBean;
import org.springframework.transaction.PlatformTransactionManager;
import org.springframework.transaction.annotation.EnableTransactionManagement;

import javax.sql.DataSource;
import java.util.Objects;

/**
* @author tongJie
* @date 2021/12/21 11:59
* <p>
* description  日志处理端数据库配置
*/
@Configuration
@EnableTransactionManagement
@EnableJpaRepositories(
       // 配置连接工厂
       entityManagerFactoryRef = "tes1Factory",
       // 配置事物管理器
       transactionManagerRef = "tes1Transaction",
       // 设置Jpa 的 repository所在位置
       basePackages = {"com.xx.xx.xx.**.repository"}
)
// 设置扫描的mapper
@MapperScan(basePackages ="xx.xx.xx.test1.**.mapper", sqlSessionTemplateRef  = "tes1SqlSessionTemplate")
public class AnalysisDataBaseConfig {

@Autowired
   @Qualifier("tes1DataSource")
   private DataSource analysisDataSource;

@Autowired
   private JpaProperties jpaProperties;

@Autowired
   private HibernateProperties properties;

// 以下是jpa的配置

/**
    * 连接工厂
    * @param builder 创建工具
    * @return 结果
    */
   @Bean(name = "tes1Factory")
   public LocalContainerEntityManagerFactoryBean tes1Factory(EntityManagerFactoryBuilder builder) {
       return builder
               // 设置数据源
               .dataSource(analysisDataSource)
               //设置实体类所在位置.扫描所有带有 @Entity 注解的类
               .packages("xx.xx.xx.tes1.**.entity")
               // Spring会将EntityManagerFactory注入到Repository之中.有了 EntityManagerFactory之后,
               // Repository就能用它来创建 EntityManager 了,然后 EntityManager 就可以针对数据库执行操作
               .persistenceUnit("tes1")
               // 为了加载yml中jpa下hibernate的相关配置
               .properties(properties.determineHibernateProperties(jpaProperties.getProperties(), new HibernateSettings()))
               .build();

}

/**
    * 配置事物管理器
    *
    * @param builder 创建工具
    * @return 结果
    */
   @Bean(name = "tes1Transaction")
   PlatformTransactionManager tes1Transaction(EntityManagerFactoryBuilder builder) {
       return new JpaTransactionManager(Objects.requireNonNull(analysisFactory(builder).getObject()));
   }

// 以下是mybatis的配置

/**
    * 配置sqlSessionFactory
    * @return 结果
    * @throws Exception 异常
    */
   @Bean("tes1SqlSessionFactory")
   public SqlSessionFactory tes1SqlSessionFactory() throws Exception {
       MybatisSqlSessionFactoryBean sqlSessionFactory = new MybatisSqlSessionFactoryBean();
       sqlSessionFactory.setDataSource(analysisDataSource);
       sqlSessionFactory.setMapperLocations(new
       //这里填写你mybaits的xml文件存放的路径
       PathMatchingResourcePatternResolver().getResources("classpath:mybatis/mapper/*.xml"));
       return sqlSessionFactory.getObject();
   }

/**
    * 配置sqlSessionTemplate
    * @return 结果
    */
   @Bean(name = "tes1SqlSessionTemplate")
   public SqlSessionTemplate tes1SqlSessionTemplate() throws Exception {
       return new SqlSessionTemplate(tes1SqlSessionFactory());
   }
}

以此类推之后每增加一个数据库源就循环上面的方法
注意!!!!包一定要放对你配置的位置,否则不识别就会报错!!!!!!

来源:https://blog.csdn.net/weixin_42782429/article/details/122084847

标签:SpringBoot,Jpa,双数据库源
0
投稿

猜你喜欢

  • SpringBoot如何进行对象复制的实践

    2023-11-23 03:40:19
  • java实现超市管理系统

    2022-06-23 13:19:06
  • Android启动页出现白屏、黑屏的解决方案

    2022-08-23 21:11:52
  • 封装的android监听手指左右滑动屏幕的事件类分享

    2021-10-21 07:10:08
  • android实现okHttp的get和post请求的简单封装与使用

    2023-10-06 04:20:25
  • Android Path绘制贝塞尔曲线实现QQ拖拽泡泡

    2023-03-16 07:57:24
  • C# KeyUp事件中MessageBox的回车(Enter)键回调问题解决方案

    2021-06-25 06:24:06
  • c#生成验证码程序

    2023-01-08 18:38:59
  • Android实现屏幕保持常亮功能

    2023-08-09 13:20:15
  • Android高级动画篇之SVG矢量动画范例

    2022-09-28 11:01:00
  • Java中Map的遍历方法及性能测试

    2023-07-14 08:54:15
  • C# 9.0 特性全面总结

    2023-07-21 16:28:19
  • Android中SparseArray性能优化的使用方法

    2023-08-24 22:26:20
  • Spring中自动注入的两种方式总结

    2022-10-24 08:54:14
  • Spring实战之使用注解实现声明式事务操作示例

    2021-08-19 07:16:07
  • Java并发编程之线程之间的共享和协作

    2021-07-20 14:28:27
  • C#获取路由器外网IP,MAC地址的实现代码

    2021-07-03 06:01:32
  • IntelliJ IDEA中查看文件内所有已声明的方法(类似eclipse的outline)

    2021-08-06 00:39:39
  • Visual C#中如何使用IComparable和IComparer接口

    2021-12-17 20:01:02
  • 一文搞懂Java ScheduledExecutorService的使用

    2022-11-22 14:23:35
  • asp之家 软件编程 m.aspxhome.com