赞
踩
软件开发是一门实践性科学,对大多数人来说,学习一种新技术不是一开始就去深究其原理,而是先从做出一个可工作的DEMO入手。但在我个人学习和工作经历中,每次学习新技术总是要花费或多或少的时间、检索不止一篇资料才能得出一个可工作的DEMO,这占用了我大量的时间精力。因此本文旨在通过一篇文章即能还原出可工作的、甚至可用于生产的DEMO,期望初学者能尽快地迈过0到1的这一步骤,并在此基础上不断深化对相关知识的理解。
为达以上目的,本文会将开发环境、工程目录结构、开发步骤及源码尽量全面地展现出来,文字描述能简则简,能用代码注释的绝不在正文中再啰嗦一遍,正文仅对必要且关键的信息做重点描述。
在 《【Spring Boot 3】【数据源】自定义JDBC多数据源》 、《【Spring Boot 3】【数据源】自定义JPA多数据源》 和 《【Spring Boot 3】【数据源】自定义MyBatis多数据源》 中分别说明了开发Spring Boot应用集成JDBC、JPA、MyBatis实现数据库操作时如何自定义多数据源,有时开发可能需要使用多种数据库访问技术和ORM框架,本文介绍在同时启用JDBC、JPA、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> 准备3个数据源(创建3个数据库)。
-- 创建第一个数据源 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'@'%';
-- 创建第三个数据源 CREATE SCHEMA IF NOT EXISTS `db3` DEFAULT CHARACTER SET utf8mb4 COLLATE utf8mb4_bin; -- 创建第三个数据源中的数据表 CREATE TABLE IF NOT EXISTS `db3`.`manufacturer` ( `id` BIGINT UNSIGNED NOT NULL AUTO_INCREMENT COMMENT '自增主键', `name` VARCHAR(100) NOT NULL COMMENT '制造商名称', `address` VARCHAR(100) 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 'userC'@'%'; CREATE USER 'userC'@'%' IDENTIFIED BY '789789'; -- 给用户赋予访问第三个数据源的权限 GRANT ALL PRIVILEGES ON db3.* TO 'userC'@'%';
2> 创建Maven工程,添加依赖。
<?xml version="1.0" encoding="UTF-8"?> <project xmlns="http://maven.apache.org/POM/4.0.0" xmlns:xsi="http://www.w3.org/2001/XMLSchema-instance" xsi:schemaLocation="http://maven.apache.org/POM/4.0.0 http://maven.apache.org/xsd/maven-4.0.0.xsd"> <modelVersion>4.0.0</modelVersion> <parent> <groupId>com.jiyongliang</groupId> <artifactId>springboot3-datasource</artifactId> <version>0.0.1</version> </parent> <artifactId>springboot3-datasource-mix-multi</artifactId> <properties> <java.version>21</java.version> <maven.compiler.source>21</maven.compiler.source> <maven.compiler.target>21</maven.compiler.target> <project.build.sourceEncoding>UTF-8</project.build.sourceEncoding> <spring-boot.version>3.2.2</spring-boot.version> <mysql-connector-j.version>8.3.0</mysql-connector-j.version> <mybatis-plus.version>3.5.5</mybatis-plus.version> <mybatis-spring.version>3.0.3</mybatis-spring.version> <lombok.version>1.18.30</lombok.version> </properties> <dependencyManagement> <dependencies> <dependency> <groupId>org.springframework.boot</groupId> <artifactId>spring-boot-dependencies</artifactId> <version>${spring-boot.version}</version> <type>pom</type> <scope>import</scope> </dependency> </dependencies> </dependencyManagement> <dependencies> <dependency> <groupId>org.springframework.boot</groupId> <artifactId>spring-boot-starter-data-jpa</artifactId> </dependency> <dependency> <groupId>org.springframework.boot</groupId> <artifactId>spring-boot-starter-jdbc</artifactId> </dependency> <dependency> <groupId>org.springframework.boot</groupId> <artifactId>spring-b
Copyright © 2003-2013 www.wpsshop.cn 版权所有,并保留所有权利。