Java实现双数据源的配置

一、环境准备

新建一个Spring Boot项目,然后在pom.xml中引入相关依赖

<dependency>
    <groupId>mysql</groupId>
    <artifactId>mysql-connector-java</artifactId>
</dependency>

<dependency>
    <groupId>com.microsoft.sqlserver</groupId>
    <artifactId>mssql-jdbc</artifactId>
    <version>6.5.4.jre8-preview</version>
    <scope>test</scope>
</dependency>
<dependency>
    <groupId>com.microsoft.sqlserver</groupId>
    <artifactId>sqljdbc4</artifactId>
    <version>4.0</version>
</dependency>

<dependency>
    <groupId>org.aspectj</groupId>
    <artifactId>aspectjweaver</artifactId>
    <version>1.9.2</version>
 </dependency>

二、数据源配置

本文用到的两个数据源分别是MySQL数据库和SqlServer数据库,其中MySQL数据库为主数据库(可自行更改)


spring:
  datasource:
    ##配置主数据库
    primary:
      jdbc-url: jdbc:mysql://xx.x.x.xxx:3306/quality?useUnicode=true&characterEncoding=UTF-8&serverTimezone=UTC&useSSL=false
      username: xxx
      password: xxx
      driver-class-name: com.mysql.cj.jdbc.Driver

    ##配置次数据库
    secondary:
      jdbc-url: jdbc:sqlserver://xxx.xxx.xxx.x:1433;DatabaseName=quality
      username: sa
      password: xxx
      driver-class-name: com.microsoft.sqlserver.jdbc.SQLServerDriver

三、创建数据源配置类

完成数据源的配置后,需创建数据源的配置类;其作用是帮助项目区分spring.datasource.primary和secondary。
第一个配置类:

package com.chinameyer.qualitymanagementsystem.config;

import org.apache.ibatis.session.SqlSessionFactory;
import org.mybatis.spring.SqlSessionFactoryBean;
import org.mybatis.spring.SqlSessionTemplate;
import org.mybatis.spring.annotation.MapperScan;
import org.springframework.beans.factory.annotation.Qualifier;
import org.springframework.boot.context.properties.ConfigurationProperties;
import org.springframework.boot.jdbc.DataSourceBuilder;
import org.springframework.context.annotation.Bean;
import org.springframework.context.annotation.Configuration;
import org.springframework.context.annotation.Primary;

import javax.sql.DataSource;


@Configuration
// 配置mybatis的接口类放的地方
@MapperScan(basePackages = "com.chinameyer.qualitymanagementsystem.dao.one", sqlSessionFactoryRef = "PrimarySqlSessionFactory")
public class PrimaryDataSourceConfig {

    // 将这个对象放入Spring容器中
    @Bean(name = "PrimaryDataSource")
    // 表示这个数据源是默认数据源
    @Primary
    // 读取application.properties中的配置参数映射成为一个对象
    // prefix表示参数的前缀
    @ConfigurationProperties(prefix = "spring.datasource.primary")
    public DataSource getPrimaryDateSource() {
        return DataSourceBuilder.create().build();
    }


    @Bean(name = "PrimarySqlSessionFactory")
    // 表示这个数据源是默认数据源
    @Primary
    // @Qualifier表示查找Spring容器中名字为test1DataSource的对象
    public SqlSessionFactory primarySqlSessionFactory(@Qualifier("PrimaryDataSource") DataSource datasource)
            throws Exception {
        SqlSessionFactoryBean bean = new SqlSessionFactoryBean();
        bean.setDataSource(datasource);
        return bean.getObject();
    }
    @Bean("PrimarySqlSessionTemplate")
    // 表示这个数据源是默认数据源
    @Primary
    public SqlSessionTemplate primarySqlSessionTemplate(
            @Qualifier("PrimarySqlSessionFactory") SqlSessionFactory sessionfactory) {
        return new SqlSessionTemplate(sessionfactory);
    }
}

第二个配置类:

package com.chinameyer.qualitymanagementsystem.config;


import org.apache.ibatis.session.SqlSessionFactory;
import org.mybatis.spring.SqlSessionFactoryBean;
import org.mybatis.spring.SqlSessionTemplate;
import org.mybatis.spring.annotation.MapperScan;
import org.springframework.beans.factory.annotation.Qualifier;
import org.springframework.boot.context.properties.ConfigurationProperties;
import org.springframework.boot.jdbc.DataSourceBuilder;
import org.springframework.context.annotation.Bean;
import org.springframework.context.annotation.Configuration;
import org.springframework.core.io.support.PathMatchingResourcePatternResolver;

import javax.sql.DataSource;

@Configuration
@MapperScan(basePackages = "com.chinameyer.qualitymanagementsystem.dao.two", sqlSessionFactoryRef = "SecondarySqlSessionFactory")
public class SecondaryDataSourceConfig {


    @Bean(name = "SecondaryDataSource")
    @ConfigurationProperties(prefix = "spring.datasource.secondary")
    public DataSource getSecondaryDataSource() {
        return DataSourceBuilder.create().build();
    }
    @Bean(name = "SecondarySqlSessionFactory")
    public SqlSessionFactory secondarySqlSessionFactory(@Qualifier("SecondaryDataSource") DataSource datasource)
            throws Exception {
        SqlSessionFactoryBean bean = new SqlSessionFactoryBean();
        bean.setDataSource(datasource);
        return bean.getObject();
    }
    @Bean("SecondarySqlSessionTemplate")
    public SqlSessionTemplate secondarySqlSessionTemplate(
            @Qualifier("SecondarySqlSessionFactory") SqlSessionFactory sessionfactory) {
        return new SqlSessionTemplate(sessionfactory);
    }
}

四、自定义注解 @DataSource

通过自定义的注解@DataSource,方便在对数据库操作时,确定其操作的对象。

package com.chinameyer.qualitymanagementsystem.service;

/**
 * @Author HongYe
 * @Date 2019/12/26 9:29
 */

import java.lang.annotation.*;

@Target({ElementType.METHOD, ElementType.TYPE, ElementType.PARAMETER})
@Retention(RetentionPolicy.RUNTIME)
@Documented
public @interface DataSource {
    String value() default "primary"; //默认使用默认数据库
}

五、通过AOP的方式实现多数据源

通常可以通过分包实现多数据源的,检测多数据源存在的事务管理问题、通过jta-atomikos解决传统项目多数据源事务管理问题以及通过aop的方式实现多数据源,该处使用的是最后一种方式。
通过使用aop拦截,获取注解的属性value的值。如果value的值并没有在我们DataBaseType里面,则使用我们默认的数据源,如果有的话,则切换为相应的数据源。

package com.chinameyer.qualitymanagementsystem.service;

import com.chinameyer.qualitymanagementsystem.entity.DataSourceType;
import org.aspectj.lang.JoinPoint;
import org.aspectj.lang.annotation.After;
import org.aspectj.lang.annotation.Aspect;
import org.aspectj.lang.annotation.Before;
import org.springframework.stereotype.Component;

/**
 * @Author HongYe
 * @Date 2019/12/26 9:29
 */
@Aspect
@Component
public class DynamicDataSourceAspect {

    @Before("@annotation(dataSource)")//拦截我们的注解
    public void changeDataSource(JoinPoint point, DataSource dataSource) throws Throwable {
        String value = dataSource.value();
        if (value.equals("primary")){
            DataSourceType.setDataBaseType(DataSourceType.DataBaseType.Primary);
        }else if (value.equals("secondary")){
            DataSourceType.setDataBaseType(DataSourceType.DataBaseType.Secondary);
        }else {
            DataSourceType.setDataBaseType(DataSourceType.DataBaseType.Primary);//默认使用主数据库
        }
    }

    @After("@annotation(dataSource)") //清除数据源的配置
    public void restoreDataSource(JoinPoint point, DataSource dataSource) {
        DataSourceType.clearDataBaseType();
    }
}

六、在Dao层写操作数据库的SQL语句

package com.chinameyer.qualitymanagementsystem.dao.one;

import com.chinameyer.qualitymanagementsystem.entity.SqlProvider;
import com.chinameyer.qualitymanagementsystem.service.DataSource;
import org.apache.ibatis.annotations.Delete;
import org.apache.ibatis.annotations.Param;
import org.apache.ibatis.annotations.Select;
import org.apache.ibatis.annotations.SelectProvider;

import java.util.List;

/**
 * @Author HongYe
 * @Date 2019/12/31 10:03
 */
public interface BmDao {

    /**
     * 清空表中数据
     */
    @DataSource
    @Delete("truncate table bm")
    void updateThisTable();
}
package com.chinameyer.qualitymanagementsystem.dao.two;

import com.chinameyer.qualitymanagementsystem.entity.BHGDJCLB;
import com.chinameyer.qualitymanagementsystem.entity.BM;
import com.chinameyer.qualitymanagementsystem.service.DataSource;
import org.apache.ibatis.annotations.Select;

import java.util.List;

/**
 * @Author HongYe
 * @Date 2019/12/31 10:04
 */
public interface BmSecondaryDao {
    /**
     * 从MSSQL中获取所有的BM
     * @return
     */
    @DataSource("secondary")
    @Select("select 部门编号 as departmentNumber,部门名称 as departmentName from bm")
    List<BM> findAllEntityFromMssql();
}

最后写一个测试类,查看是否分别实现了对主、从数据库的操作!!!至少我实现了

  • 1
    点赞
  • 8
    收藏
    觉得还不错? 一键收藏
  • 4
    评论
nacos支持数据源配置,可以通过在配置文件中添加第二个数据源配置实现。具体步骤如下: 1. 配置文件中添加第二个数据源配置,包括驱动类名、连接地址、用户名和密码等信息。例如: ```yaml spring: datasource: datasource1: driver-class-name: com.mysql.jdbc.Driver url: jdbc:mysql://localhost:3306/db1 username: root password: 123456 datasource2: driver-class-name: com.mysql.jdbc.Driver url: jdbc:mysql://localhost:3307/db2 username: root password: 123456 ``` 2. 在项目中使用`@Configuration`注解创建一个配置类,用于配置数据源。在该类中创建两个数据源的`DataSource`对象,并将其注入到`Spring`容器中。例如: ```java @Configuration public class DataSourceConfig { @Bean(name = "datasource1") @ConfigurationProperties(prefix = "spring.datasource.datasource1") public DataSource dataSource1() { return DataSourceBuilder.create().build(); } @Bean(name = "datasource2") @ConfigurationProperties(prefix = "spring.datasource.datasource2") public DataSource dataSource2() { return DataSourceBuilder.create().build(); } } ``` 3. 在需要使用数据源的地方,通过`@Qualifier`注解指定使用哪个数据源。例如: ```java @Autowired @Qualifier("datasource1") private DataSource datasource1; @Autowired @Qualifier("datasource2") private DataSource datasource2; ``` 以上是配置nacos数据源的方法。通过在配置文件中添加第二个数据源配置,然后在项目中创建对应的数据源对象,并将其注入到Spring容器中,就可以实现数据源配置了。

“相关推荐”对你有帮助么?

  • 非常没帮助
  • 没帮助
  • 一般
  • 有帮助
  • 非常有帮助
提交
评论 4
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值