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

相关推荐
不羁。。几秒前
【撸靶笔记】第七关:GET - Dump into outfile - String
数据库·笔记·oracle
yangchanghua1111 小时前
pgsql 如何查询今天范围内的数据(当天0点0分0秒 - 当天23点59分59秒....)
数据库·pgsql
larance2 小时前
SQLAlchemy 的异步操作来批量保存对象列表
数据库·python
python_chai2 小时前
从数据汇总到高级分析,SQL 查询进阶实战(下篇)—— 分组、子查询与窗口函数全攻略
数据库·sql·mysql
在努力的前端小白2 小时前
Spring Boot 敏感词过滤组件实现:基于DFA算法的高效敏感词检测与替换
java·数据库·spring boot·文本处理·敏感词过滤·dfa算法·组件开发
未来之窗软件服务2 小时前
自建知识库,向量数据库 (九)之 量化前奏分词服务——仙盟创梦IDE
数据库·仙盟创梦ide·东方仙盟·自建ai·ai分词
好望角雾眠5 小时前
第一阶段C#基础-10:集合(Arraylist,list,Dictionary等)
笔记·学习·c#
冒泡的肥皂5 小时前
MVCC初学demo(一
数据库·后端·mysql
.Shu.6 小时前
Redis Reactor 模型详解【基本架构、事件循环机制、结合源码详细追踪读写请求从客户端连接到命令执行的完整流程】
数据库·redis·架构
yatingliu20197 小时前
HiveQL | 个人学习笔记
hive·笔记·sql·学习