【Spring Data教程】2.SpringBoot整合dynamic-datasource配置多数据源

前言

上篇讲到了使用Spring Jdbc 自定义配置多数据源,简单的业务场景可以处理,复制的情况不方便处理,如:配置主从、读写、多主多从情况。dynamic-datasource就是解决这个问题的,当然解决多数据源的问题绰绰有余了。

Dynamic-datasource复杂的条件配置

image-20220528144316887

详细参考:https://www.kancloud.cn/tracy5546/dynamic-datasource/2264611

环境搭建

pom.xml依赖

<parent>
    <groupId>org.springframework.boot</groupId>
    <artifactId>spring-boot-starter-parent</artifactId>
    <version>2.4.2</version>
</parent>

<dependencies>
    <!-- jdbc -->
    <dependency>
        <groupId>org.springframework.boot</groupId>
        <artifactId>spring-boot-starter-jdbc</artifactId>
    </dependency>
    <!-- mysql -->
    <dependency>
        <groupId>mysql</groupId>
        <artifactId>mysql-connector-java</artifactId>
    </dependency>
    <!-- spring boot 单元测试依赖 -->
    <dependency>
        <groupId>org.springframework.boot</groupId>
        <artifactId>spring-boot-starter-test</artifactId>
    </dependency>
</dependencies>

yml配置

spring:
  datasource:
    dynamic:
      primary: data1 #设置默认的数据源或者数据源组
      strict: false #严格匹配数据源,默认false. true未匹配到指定数据源时抛异常,false使用默认数据源
      datasource:
        data1:
          url: jdbc:mysql://192.168.126.156:3306/test
          username: root
          password: 123456
          driver-class-name: com.mysql.jdbc.Driver # 3.2.0开始支持SPI可省略此配置
        data2:
          url: jdbc:mysql://192.168.126.157:3306/test
          username: root
          password: 123456
          driver-class-name: com.mysql.jdbc.Driver

测试类

import com.baomidou.dynamic.datasource.annotation.DS;
import com.terry.App;
import org.junit.jupiter.api.Test;
import org.springframework.beans.factory.annotation.Autowired;
import org.springframework.boot.test.context.SpringBootTest;
import org.springframework.jdbc.core.JdbcTemplate;

import java.util.List;
import java.util.Map;

@SpringBootTest(classes = App.class)
public class TestJdbcTemplate {

    @Autowired
    private JdbcTemplate jdbcTemplate;

    // @DS("data1") 没有则是默认数据源
    public void test1(){
        List<Map<String, Object>> users = jdbcTemplate.queryForList(" SELECT * FROM user ");
        System.out.println("数据库1数据:" + users);
    }

    @DS("data2")
    public void test2(){
        List<Map<String, Object>> roles = jdbcTemplate.queryForList(" SELECT * FROM role ");
        System.out.println("数据库2数据:" + roles);
    }

    @Test
    public void queryTest(){
        test1();
        test2();
    }
}

测试成功,打印日志如下:

2022-05-28 15:01:38.274  INFO 5928 --- [           main] c.b.d.d.DynamicRoutingDataSource         : dynamic-datasource - add a datasource named [data2] success
2022-05-28 15:01:38.274  INFO 5928 --- [           main] c.b.d.d.DynamicRoutingDataSource         : dynamic-datasource - add a datasource named [data1] success
2022-05-28 15:01:38.274  INFO 5928 --- [           main] c.b.d.d.DynamicRoutingDataSource         : dynamic-datasource initial loaded [2] datasource,primary datasource named [data1]
2022-05-28 15:01:38.429  INFO 5928 --- [           main] com.terry.test.TestJdbcTemplate          : Started TestJdbcTemplate in 2.789 seconds (JVM running for 3.762)
数据库1数据:[{id=1, name=1}]
数据库2数据:[{user_id=1}]
  • 3
    点赞
  • 6
    收藏
    觉得还不错? 一键收藏
  • 打赏
    打赏
  • 0
    评论
好的,您可以按照以下步骤进行操作: 1. 首先,您需要在 `application.properties` 文件中添加以下配置配置您的两个数据源: ``` # 主数据源配置 spring.datasource.dynamic.datasource.master.driver-class-name=oracle.jdbc.OracleDriver spring.datasource.dynamic.datasource.master.url=jdbc:oracle:thin:@10.178.8.137:1521:gsjzzdb spring.datasource.dynamic.datasource.master.username=your_master_username spring.datasource.dynamic.datasource.master.password=your_master_password # 从数据源配置 spring.datasource.dynamic.datasource.slave.driver-class-name=oracle.jdbc.OracleDriver spring.datasource.dynamic.datasource.slave.url=jdbc:oracle:thin:@your_slave_url spring.datasource.dynamic.datasource.slave.username=your_slave_username spring.datasource.dynamic.datasource.slave.password=your_slave_password ``` 2. 接下来,您需要在您的 DAO 层接口中使用 `@DS("slave")` 注解来指定当前数据源为从数据源。 ```java @Mapper public interface YourMapper { @DS("slave") List<YourResultEntity> selectFromBothTables(); } ``` 3. 然后,您需要在 Mapper XML 文件中编写您的 SQL 语句,使用左连接的方式连接两个表,并将查询结果映射到一个实体类中。 ```xml <select id="selectFromBothTables" resultType="YourResultEntity"> SELECT t1.*, t2.* FROM table1 t1 LEFT JOIN table2 t2 ON t1.id = t2.id </select> ``` 4. 在实体类中使用 `@TableName` 注解来指定映射的表名。 ```java @Data @TableName("your_table_name") public class YourResultEntity { // 实体类的属性 } ``` 以上就是使用 MyBatis-Plus 连接两个数据库的两个表并使用左连接的方式执行 SQL 语句,并将查询结果映射到一个实体类中并指定表名的步骤。

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

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

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包

打赏作者

terrybg

你的鼓励将是我创作的最大动力

¥1 ¥2 ¥4 ¥6 ¥10 ¥20
扫码支付:¥1
获取中
扫码支付

您的余额不足,请更换扫码支付或充值

打赏作者

实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

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

余额充值