Spring Boot笔记-使用dynamic-datasource配置多元数据库(MySQL和达梦)

以前都用JPA,配置多元数据库稍微麻烦那面一点点,这几天看了下年轻人的Java代码,发现Mybatis用得比较多了,而且还有比较好用的三方库,配置多元数据库,相对简单,在此记录下。方便以后使用。

Maven导入:

XML 复制代码
<dependency>
    <groupId>com.baomidou</groupId>
    <artifactId>dynamic-datasource-spring-boot-starter</artifactId>
    <version>3.5.0</version>
</dependency>

在yml文件中配置,官方只给出了yml。properties没有提,但看了yml后,发现的确比properties要简洁好用多了。

bash 复制代码
spring:
  datasource:
    dynamic:
      primary: mysql
      datasource:
        mysql:
          url: jdbc:mysql://127.0.0.1:3306/XXX?characterEncoding=utf-8&useSSL=false
          username: root
          password: root
          driver-class-name: com.mysql.jdbc.Driver
        dm7:
          url: jdbc:dm://127.0.0.1/XXX?characterEncoding=utf-8&useSSL=false
          username: SYSDBA
          password: SYSDBA
          driver-class-name: dm.jdbc.driver.DmDriver

这里有点要注意的primary必须指定一个,不然项目启动后会报错。

使用就相当简单了,用注解就可以了。下面我用jdbctemplate来调用下。

MySQLTest.java

java 复制代码
package cn.demo.test;

import com.baomidou.dynamic.datasource.annotation.DS;
import org.springframework.beans.factory.annotation.Autowired;
import org.springframework.jdbc.core.JdbcTemplate;
import org.springframework.stereotype.Component;

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

@Component
@DS("mysql")
public class MySQLTest {

    @Autowired
    private JdbcTemplate jdbcTemplate;

    public List<Map<String, Object>> test(){
        return jdbcTemplate.queryForList("select * from XXX.XXX");
    }
}

DMTest.java

java 复制代码
package cn.demo.test;

import com.baomidou.dynamic.datasource.annotation.DS;
import org.springframework.beans.factory.annotation.Autowired;
import org.springframework.jdbc.core.JdbcTemplate;
import org.springframework.stereotype.Component;

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

@Component
@DS("dm7")
public class DMTest {

    @Autowired
    private JdbcTemplate jdbcTemplate;

    public List<Map<String, Object>> test(){
        return jdbcTemplate.queryForList("select * from XXX.XXX");
    }
}

TestMain.java

java 复制代码
package cn.demo;

import cn.demo.test.DMTest;
import cn.demo.test.MySQLTest;
import org.springframework.beans.factory.annotation.Autowired;
import org.springframework.boot.CommandLineRunner;
import org.springframework.boot.SpringApplication;
import org.springframework.boot.autoconfigure.SpringBootApplication;

@SpringBootApplication
public class TestMain  implements CommandLineRunner {

    @Autowired
    DMTest dmTest;

    @Autowired
    MySQLTest mySQLTest;

    public static void main(String[] args) {
        SpringApplication.run(TestMain.class, args);
    }

    public void run(String... args) throws Exception {

        System.out.println(dmTest.test());
        System.out.println(mySQLTest.test());
    }
}

启动后打印这个,就是成功了

源码打包下载地址:

Java/dynamic-datasource-demo at master · fengfanchen/Java · GitHub

相关推荐
啦啦啦~~~7541 分钟前
【最新版】Edge浏览器安装!绿色增强版+禁止Edge更新的软件+彻底卸载Edge软件
数据库·阿里云·电脑·.net·edge浏览器
d111111111d3 分钟前
编码器测速详情解释:PID闭环控制
笔记·stm32·单片机·嵌入式硬件·学习·算法
程序边界6 分钟前
金仓数据库助力Oracle迁移:一场国产数据库的逆袭之旅
数据库·oracle
为什么不问问神奇的海螺呢丶7 分钟前
oracle RAC开关机步骤
数据库·oracle
风123456789~9 分钟前
【健康管理】第8章 身体活动基本知识 1/2
笔记·考证·健康管理
后端小张9 分钟前
【Java 进阶】深入理解Redis:从基础应用到进阶实践全解析
java·开发语言·数据库·spring boot·redis·spring·缓存
TDengine (老段)11 分钟前
TDengine IDMP 1.0.9.0 上线:数据建模、分析运行与可视化能力更新一览
大数据·数据库·物联网·ai·时序数据库·tdengine·涛思数据
云老大TG:@yunlaoda36018 分钟前
如何使用华为云国际站代理商的BRS进行数据安全保障?
大数据·数据库·华为云·云计算
(づど)18 分钟前
一套齐全的环境设置:nvm\node\nrm\pnpm
前端·笔记
野生技术架构师20 分钟前
SpringBoot+Elasticsearch实现高效全文搜索
spring boot·elasticsearch·jenkins