【Spring Boot 3】【数据源】自定义MyBatis多数据源

【Spring Boot 3】【数据源】自定义MyBatis多数据源

背景

软件开发是一门实践性科学,对大多数人来说,学习一种新技术不是一开始就去深究其原理,而是先从做出一个可工作的DEMO入手。但在我个人学习和工作经历中,每次学习新技术总是要花费或多或少的时间、检索不止一篇资料才能得出一个可工作的DEMO,这占用了我大量的时间精力。因此本文旨在通过一篇文章即能还原出可工作的、甚至可用于生产的DEMO,期望初学者能尽快地迈过0到1的这一步骤,并在此基础上不断深化对相关知识的理解。
为达以上目的,本文会将开发环境、工程目录结构、开发步骤及源码尽量全面地展现出来,文字描述能简则简,能用代码注释的绝不在正文中再啰嗦一遍,正文仅对必要且关键的信息做重点描述。

介绍

《【Spring Boot 3】【数据源】自定义JDBC多数据源》《【Spring Boot 3】【数据源】自定义JPA多数据源》 中分别说明了开发Spring Boot JDBC应用和JPA应用时如何自定义数据源,除JPA外MyBatis也是一个较为流行的ORM框架,本文介绍Spring Boot集成MyBatis框架时如何自定义数据源。

开发环境

分类 名称 版本
操作系统 Windows Windows 11
JDK Oracle JDK 21.0.1
IDE IntelliJ IDEA 2023.2.4
构建工具 Apache Maven 3.9.3
数据库 MySQL 8.0.33

开发步骤及源码

1> 准备2个数据源(创建2个数据库)。

  • 数据源一
-- 创建第一个数据源
CREATE SCHEMA IF NOT EXISTS `db1` DEFAULT CHARACTER SET utf8mb4 COLLATE utf8mb4_bin;

-- 创建第一个数据源中的数据表
CREATE TABLE IF NOT EXISTS `db1`.`product`
(
    `id`    BIGINT UNSIGNED NOT NULL AUTO_INCREMENT COMMENT '自增主键',
    `name`  VARCHAR(100)    NOT NULL COMMENT '产品名称',
    `price` DECIMAL         NOT NULL COMMENT '产品价格',
    PRIMARY KEY (`id`),
    UNIQUE INDEX `id_UNIQUE` (`id` ASC) VISIBLE
)
    ENGINE = InnoDB
    DEFAULT CHARACTER SET = utf8mb4
    COLLATE = utf8mb4_bin;

-- 创建用户
DROP USER IF EXISTS 'userA'@'%';
CREATE USER 'userA'@'%' IDENTIFIED BY '123123';

-- 给用户赋予访问第一个数据源的权限
GRANT ALL PRIVILEGES ON db1.* TO 'userA'@'%';
  • 数据源二
-- 创建第二个数据源
CREATE SCHEMA IF NOT EXISTS `db2` DEFAULT CHARACTER SET utf8mb4 COLLATE utf8mb4_bin;

-- 创建第二个数据源中的数据表
CREATE TABLE IF NOT EXISTS `db2`.`customer`
(
    `id`   BIGINT UNSIGNED NOT NULL AUTO_INCREMENT COMMENT '自增主键',
    `name` VARCHAR(100)    NOT NULL COMMENT '顾客名称',
    `age`  INT             NOT NULL COMMENT '年龄',
    PRIMARY KEY (`id`),
    UNIQUE INDEX `id_UNIQUE` (`id` ASC) VISIBLE
)
    ENGINE = InnoDB
    DEFAULT CHARACTER SET = utf8mb4
    COLLATE = utf8mb4_bin;

-- 创建用户
DROP USER IF EXISTS 'userB'@'%';
CREATE USER 'userB'@'%' IDENTIFIED BY '456456';

-- 给用户赋予访问第二个数据源的权限
GRANT ALL PRIVILEGES ON db2.* TO 'userB'@'%';

2> 创建Maven工程,添加依赖。

    <properties>
        <spring-boot.version>3.2.1</spring-boot.version>
    </properties>

    <dependencies>
        <dependency>
            <groupId>org.springframework.boot</groupId>
            <artifactId>spring-boot-starter</artifactId>
            <version>${spring-boot.version}</version>
        </dependency>
        <dependency>
            <groupId>org.springframework.boot</groupId>
            <artifactId>spring-boot-starter-test</artifactId>
            <version>${spring-boot.version}</version>
            <scope>test</scope>
        </dependency>
        <dependency>
            <groupId>com.baomidou</groupId>
            <artifactId>mybatis-plus-boot-starter</artifactId>
            <version>3.5.5</version>
            <exclusions>
                <exclusion>
                    <groupId>org.mybatis</groupId>
                    <artifactId>mybatis-spring</artifactId>
                </exclusion>
            </exclusions>
        </dependency>
        <dependency>
            <groupId>org.mybatis</groupId>
            <artifactId>mybatis-spring</artifactId>
            <version>3.0.3</version>
        </dependency>
        <dependency>
            <groupId>com.mysql</groupId>
            <artifactId>mysql-connector-j</artifactId>
            <version>8.2.0</version&

相关推荐

  1. 【Spring Boot 3】【数据】自定义MyBatis数据

    2024-01-16 11:36:02       38 阅读
  2. 【Spring Boot 3】【数据】自定义数据

    2024-01-16 11:36:02       33 阅读
  3. SpringBoot整合Mybatis实现数据配置

    2024-01-16 11:36:02       10 阅读
  4. springboot数据支持自定义连接池

    2024-01-16 11:36:02       38 阅读

最近更新

  1. TCP协议是安全的吗?

    2024-01-16 11:36:02       16 阅读
  2. 阿里云服务器执行yum,一直下载docker-ce-stable失败

    2024-01-16 11:36:02       16 阅读
  3. 【Python教程】压缩PDF文件大小

    2024-01-16 11:36:02       15 阅读
  4. 通过文章id递归查询所有评论(xml)

    2024-01-16 11:36:02       18 阅读

热门阅读

  1. 【高危】Apache Solr 环境变量信息泄漏漏洞

    2024-01-16 11:36:02       33 阅读
  2. 负载均衡 LoadBalancer

    2024-01-16 11:36:02       25 阅读
  3. 两个list对象取合集、差集

    2024-01-16 11:36:02       28 阅读
  4. SEM优化三种方式

    2024-01-16 11:36:02       27 阅读
  5. Go的并发练习题目

    2024-01-16 11:36:02       36 阅读
  6. Tomcat教程

    2024-01-16 11:36:02       35 阅读
  7. 根据屏幕尺寸设置html根字号fontSize大小并刷新

    2024-01-16 11:36:02       33 阅读
  8. Ubuntu纯净服务器系统使用Nginx+uwsgi部署django项目

    2024-01-16 11:36:02       36 阅读