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

相关推荐
optimistic_chen19 小时前
【Java EE进阶 --- SpringBoot】Mybatis - plus 操作数据库
数据库·spring boot·笔记·java-ee·mybatis·mybatis-plus
凉、介19 小时前
ARM 总线技术 —— AMBA 入门
arm开发·笔记·学习
日更嵌入式的打工仔20 小时前
嵌入式入门:APP+BSP+HAL 三层分级架构浅析
笔记·单片机·嵌入式硬件·学习
FJW02081420 小时前
关系型数据库大王Mysql——DDL语句操作示例
数据库·mysql
言之。20 小时前
Chroma 开源的 AI 应用搜索与检索数据库(即向量数据库)
数据库·人工智能·开源
来旺20 小时前
互联网大厂Java面试全解析及三轮问答专项
java·数据库·spring boot·安全·缓存·微服务·面试
长桥夜波20 小时前
【第十八周】机器学习笔记07
人工智能·笔记·机器学习
摇滚侠20 小时前
Spring Boot 3零基础教程,yml文件中配置和类的属性绑定,笔记15
spring boot·redis·笔记
thginWalker20 小时前
使用Spring Boot构建消息通信层
spring boot
lang2015092820 小时前
Spring Boot 外部化配置最佳实践指南
java·spring boot