锋盈数科-知识库 Logo
首页
软件开发
计算机基础
Hello Halo
新手必读
关于本知识库
登录 →
锋盈数科-知识库 Logo
首页 软件开发 计算机基础 Hello Halo 新手必读 关于本知识库
登录
  1. 首页
  2. 软件开发
  3. JAVA
  4. Java实战:Spring Boot实现数据源配置与多数据源切换

Java实战:Spring Boot实现数据源配置与多数据源切换

0
  • JAVA
  • 发布于 2024-08-15
  • 0 次阅读
黄健
黄健

本文由 简悦 SimpRead 转码, 原文地址 blog.csdn.net

本文将详细介绍如何在 Spring Boot 应用程序中实现数据源配置与多数据源切换。我们将探讨 Spring Boot 的数据源配置方式,以及如何使用 Spring Boot 实现多数据源切换。最后,我们将通过一个具体示例来演示整个实现过程。本文适合已经具备 Spring Boot 基础知识的开发者阅读,以加深对 Spring Boot 数据源配置与多数据源切换的理解。

一、引言

在 Java 应用程序中,数据库连接是至关重要的组成部分。Spring Boot 为开发者提供了一种简便的方式来配置数据源。此外,在实际应用中,我们可能需要与多个数据库进行交互,因此需要实现多数据源切换的功能。本文将介绍如何在 Spring Boot 中实现数据源配置与多数据源切换,并通过具体示例来演示这一过程。

二、Spring Boot 数据源配置

1. 基本数据源配置
在 Spring Boot 中,我们可以通过在 application.properties 或 application.yml 文件中配置数据库连接信息来实现数据源的配置。以下是一个基本的数据库连接配置示例:

spring.datasource.url=jdbc:mysql://localhost:3306/test_db?useSSL=false
spring.datasource.username=root
spring.datasource.password=root
spring.datasource.driver-class-name=com.mysql.cj.jdbc.Driver

2. 使用数据源配置类
除了基本的属性配置外,我们还可以通过创建数据源配置类来配置数据源。以下是一个使用 HikariCP 数据源配置类的示例:

@Configuration
public class DataSourceConfig {
    @Bean
    @ConfigurationProperties(prefix = "spring.datasource")
    public DataSource dataSource() {
        return new HikariDataSource();
    }
}

三、Spring Boot 实现多数据源切换

在某些情况下,我们可能需要在一个应用程序中与多个数据库进行交互。Spring Boot 支持多数据源切换的功能,我们可以通过以下步骤来实现:
1. 配置多个数据源
首先,我们需要在 application.properties 或 application.yml 文件中配置多个数据源的信息。以下是一个配置两个数据源的示例:

spring.datasource.db1.url=jdbc:mysql://localhost:3306/test_db1?useSSL=false
spring.datasource.db1.username=root
spring.datasource.db1.password=root
spring.datasource.db1.driver-class-name=com.mysql.cj.jdbc.Driver
spring.datasource.db2.url=jdbc:mysql://localhost:3306/test_db2?useSSL=false
spring.datasource.db2.username=root
spring.datasource.db2.password=root
spring.datasource.db2.driver-class-name=com.mysql.cj.jdbc.Driver

2. 创建数据源配置类
接下来,我们需要创建一个数据源配置类,用于生成多个数据源对象。以下是一个使用 HikariCP 数据源配置类的示例:

@Configuration
public class DataSourceConfig {
    @Bean(name = "db1DataSource")
    @ConfigurationProperties(prefix = "spring.datasource.db1")
    public DataSource db1DataSource() {
        return new HikariDataSource();
    }
    @Bean(name = "db2DataSource")
    @ConfigurationProperties(prefix = "spring.datasource.db2")
    public DataSource db2DataSource() {
        return new HikariDataSource();
    }
}

3. 使用 @Qualifier 注解指定数据源
在需要使用特定数据源的地方,我们可以使用 @Qualifier 注解来指定使用哪个数据源。以下是一个使用 @Qualifier 注解的示例:

@Service
public class UserService {
    @Autowired
    @Qualifier("db1DataSource")
    private DataSource db1DataSource;
    @Autowired
    @Qualifier("db2DataSource")
    private DataSource db2DataSource;
    public void addUser(String username, int age) {
        // 使用db1DataSource插入用户数据
        // 使用db2DataSource插入用户数据
    }
}

四、具体示例

现在,我们将通过一个具体示例来演示如何在 Spring Boot 应用程序中实现数据源配置与多数据源切换。
1. 创建 Spring Boot 项目
首先,我们需要创建一个 Spring Boot 项目。在创建项目时,选择相应的项目模板和依赖。本文以 Maven 项目为例,添加以下依赖:

<dependencies>
    <!-- Spring Boot Web依赖 -->
    <dependency>
        <groupId>org.springframework.boot</groupId>
        <artifactId>spring-boot-starter-web</artifactId>
    </dependency>
    <!-- Spring Boot JPA依赖 -->
    <dependency>
        <groupId>org.springframework.boot</groupId>
        <artifactId>spring-boot-starter-data-jpa</artifactId>
    </dependency>
    <!-- MySQL驱动依赖 -->
    <dependency>
        <groupId>mysql</groupId>
        <artifactId>mysql-connector-java</artifactId>
    </dependency>
</dependencies>

2. 配置数据源
在 application.properties 文件中,添加以下数据源配置:

spring.datasource.db1.url=jdbc:mysql://localhost:3306/test_db1?useSSL=false
spring.datasource.db1.username=root
spring.datasource.db1.password=root
spring.datasource.db1.driver-class-name=com.mysql.cj.jdbc.Driver
spring.datasource.db2.url=jdbc:mysql://localhost:3306/test_db2?useSSL=false
spring.datasource.db2.username=root
spring.datasource.db2.password=root
spring.datasource.db2.driver-class-name=com.mysql.cj.jdbc.Driver

3. 创建数据源配置类
在 src/main/java/com/example/demo/config 目录下,创建一个名为 DataSourceConfig.java 的文件,用于配置两个数据源:

package com.example.demo.config;
import com.zaxxer.hikari.HikariDataSource;
import org.springframework.context.annotation.Bean;
import org.springframework.context.annotation.Configuration;
import org.springframework.context.annotation.Primary;
import org.springframework.context.annotation.Qualifier;
import javax.sql.DataSource;
@Configuration
public class DataSourceConfig {
    @Primary
    @Bean(name = "db1DataSource")
    @ConfigurationProperties(prefix = "spring.datasource.db1")
    public DataSource db1DataSource() {
        return new HikariDataSource();
    }
    @Bean(name = "db2DataSource")
    @ConfigurationProperties(prefix = "spring.datasource.db2")
    public DataSource db2DataSource() {
        return new HikariDataSource();
    }
}

4. 创建 JPA 实体类
在 src/main/java/com/example/demo/entity 目录下,创建一个名为 User.java 的文件,用于表示用户表:

package com.example.demo.entity;
import javax.persistence.Entity;
import javax.persistence.Id;
@Entity
public class User {
    @Id
    private Long id;
    private String name;
    private Integer age;
    // getter和setter方法
}

5. 创建 JPA 仓库接口
在 src/main/java/com/example/demo/repository 目录下,创建一个名为 UserRepository.java 的文件,用于定义用户仓库接口:

package com.example.demo.repository;
import com.example.demo.entity.User;
import org.springframework.data.jpa.repository.JpaRepository;
public interface UserRepository extends JpaRepository<User, Long> {
}

6. 创建 Service 类
在 src/main/java/com/example/demo/service 目录下,创建一个名为 UserService.java 的文件,用于实现用户服务:

package com.example.demo.service;
import com.example.demo.entity.User;
import com.example.demo.repository.UserRepository;
import org.springframework.beans.factory.annotation.Autowired;
import org.springframework.stereotype.Service;
@Service
public class UserService {
    @Autowired
    private UserRepository userRepository;
    public void addUser(User user) {
        userRepository.save(user);
    }
}

7. 创建 Controller 类
在 src/main/java/com/example/demo/controller 目录下,创建一个名为 UserController.java 的文件,用于实现用户控制器:

package com.example.demo.controller;
import com.example.demo.entity.User;
import com.example.demo.service.UserService;
import org.springframework.beans.factory.annotation.Autowired;
import org.springframework.web.bind.annotation.PostMapping;
import org.springframework.web.bind.annotation.RequestBody;
import org.springframework.web.bind.annotation.RestController;
@RestController
public class UserController {
    @Autowired
    private UserService userService;
    @PostMapping("/addUser")
    public String addUser(@RequestBody User user) {
        userService.addUser(user);
        return "User added successfully";
    }
}

8. 运行项目
将以上代码添加到您的 Spring Boot 项目中,并运行项目。我们可以使用 Postman 或 curl 工具向http://localhost:8080/addUser发送 POST 请求,以添加用户数据。

五、总结

本文详细介绍了如何在 Spring Boot 应用程序中实现数据源配置与多数据源切换。我们首先了解了 Spring Boot 的基本数据源配置方法,然后学习了如何使用数据源配置类来配置多个数据源。接着,我们探讨了如何使用 @Qualifier 注解在需要使用特定数据源的地方指定数据源。最后,我们通过一个具体示例演示了如何在 Spring Boot 应用程序中实现多数据源切换。
通过本文,您应该已经掌握了如何在 Spring Boot 中配置和管理多个数据源,以及在实际应用中实现多数据源切换的方法。希望本文能够帮助您在开发多数据源的 Spring Boot 应用程序时更加得心应手。如果您有任何疑问或建议,请随时留言交流。

标签: #软件开发 1171 #JAVA 991
相关文章

Spring 实现 3 种异步接口 2024-10-18 09:07

大家好,我是苏三~ 如何处理比较耗时的接口? 这题我熟,直接上异步接口,使用 Callable、WebAsyncTask 和 DeferredResult、CompletableFuture等均可实现。 但这些方法有局限性,处理结果仅返回单个值。在某些场景下,如果需要接口异步处理的同时,还持续不断地

重学SpringBoot3-集成Redis(五)之布隆过滤器 2024-10-08 11:24

更多SpringBoot3内容请关注我的专栏:《SpringBoot3》 期待您的点赞👍收藏⭐评论✍ 重学SpringBoot3-集成Redis(五)之布隆过滤器 1. 什么是布隆过滤器? * 基本概念 适用场景 2. 使用 Redis 实现布隆过滤器 * 项目依赖 Redis 配置

SpringBoot整合异步任务执行 2024-10-08 11:24

同步任务: 同步任务是在单线程中按顺序执行,每次只有一个任务在执行,不会引发线程安全和数据一致性等 并发问题 同步任务需要等待任务执行完成后才能执行下一个任务,无法同时处理多个任务,响应慢,影响用 户体验 异步任务: 异步任务是在多线程中同时执行,多个任务可以并发执行,同时处理多个请求,响应快,资源

springboot kafka多数据源,通过配置动态加载发送者和消费者 2024-10-08 11:24

前言 最近做项目,需要支持kafka多数据源,实际上我们也可以通过代码固定写死多套kafka集群逻辑,但是如果需要不修改代码扩展呢,因为kafka本身不处理额外逻辑,只是起到削峰,和数据的传递,那么就需要对架构做一定的设计了。 准备test kafka本身非常容易上手,如果我们需要单元测试,引入ja

SpringBoot 集成 Redis 2024-10-08 11:24

一:SpringBoot 集成 Redis ①Redis是一个 NoSQL(not only)数据库, 常作用缓存 Cache 使用。 ②Redis是一个中间件、是一个独立的服务器;常用的数据类型: string , hash ,set ,zset , list ③通过Redis客户端可以使用多种语

SpringBoot整合QQ邮箱 2024-10-08 11:24

SpringBoot可以通过导入依赖的方式集成多种技术,这当然少不了我们常用的邮箱,现在本章演示SpringBoot整合QQ邮箱发送邮件…. 下面按步骤进行: 1.获取QQ邮箱授权码 1.1 登录QQ邮箱 1.2 开启SMTP服务 找到下图中的SMTP服务区域,如果当前账号未开启的话自己手动开启。

目录

IT 外包服务商

  • 意见投递
  • zyf6619

软件开发应用

主菜单

  • 首页
  • 软件开发
  • 计算机基础
  • Hello Halo
  • 新手必读
  • 关于本知识库
Copyright © 2024 your company All Rights Reserved. Powered by Halo.