Spring Boot中如何配置和使用多数据源

Spring Boot中如何配置和使用多数据源

大家好,我是免费搭建查券返利机器人省钱赚佣金就用微赚淘客系统3.0的小编,也是冬天不穿秋裤,天冷也要风度的程序猿!今天,我们将深入探讨如何在Spring Boot应用中配置和使用多数据源,以满足复杂应用场景下的数据管理需求。

1. 引言

在许多现代应用中,数据存储和管理往往需要使用多个数据库,每个数据库可能有不同的访问权限、数据结构或者用途。Spring Boot提供了强大的支持来配置和管理多个数据源,使得开发者能够轻松地实现多数据源的配置和使用。

2. 准备工作

在开始之前,请确保你已经安装了以下软件和组件:

  • Java开发环境
  • Spring Boot框架
3. 创建Spring Boot项目

首先,让我们创建一个基本的Spring Boot项目。假设我们的包名是cn.juwatech.multidatasourcedemo

package cn.juwatech.multidatasourcedemo;import org.springframework.boot.SpringApplication;
import org.springframework.boot.autoconfigure.SpringBootApplication;@SpringBootApplication
public class MultiDataSourceDemoApplication {public static void main(String[] args) {SpringApplication.run(MultiDataSourceDemoApplication.class, args);}
}
4. 配置多数据源

application.properties中配置多个数据源的连接信息:

# 数据源1
spring.datasource.first.url=jdbc:mysql://localhost:3306/first_db
spring.datasource.first.username=root
spring.datasource.first.password=secret
spring.datasource.first.driver-class-name=com.mysql.jdbc.Driver# 数据源2
spring.datasource.second.url=jdbc:mysql://localhost:3306/second_db
spring.datasource.second.username=root
spring.datasource.second.password=secret
spring.datasource.second.driver-class-name=com.mysql.jdbc.Driver
5. 创建多数据源配置类

编写一个配置类,分别配置和注入多个数据源:

package cn.juwatech.multidatasourcedemo.config;import javax.sql.DataSource;
import org.springframework.boot.autoconfigure.jdbc.DataSourceBuilder;
import org.springframework.boot.context.properties.ConfigurationProperties;
import org.springframework.context.annotation.Bean;
import org.springframework.context.annotation.Configuration;
import org.springframework.context.annotation.Primary;@Configuration
public class DataSourceConfig {@Bean(name = "firstDataSource")@ConfigurationProperties(prefix = "spring.datasource.first")public DataSource firstDataSource() {return DataSourceBuilder.create().build();}@Bean(name = "secondDataSource")@ConfigurationProperties(prefix = "spring.datasource.second")public DataSource secondDataSource() {return DataSourceBuilder.create().build();}
}
6. 创建JPA Repository

为每个数据源创建对应的JPA Repository接口:

package cn.juwatech.multidatasourcedemo.repository.first;import cn.juwatech.multidatasourcedemo.model.first.FirstEntity;
import org.springframework.data.jpa.repository.JpaRepository;
import org.springframework.stereotype.Repository;@Repository
public interface FirstEntityRepository extends JpaRepository<FirstEntity, Long> {
}
package cn.juwatech.multidatasourcedemo.repository.second;import cn.juwatech.multidatasourcedemo.model.second.SecondEntity;
import org.springframework.data.jpa.repository.JpaRepository;
import org.springframework.stereotype.Repository;@Repository
public interface SecondEntityRepository extends JpaRepository<SecondEntity, Long> {
}
7. 编写实体类

分别创建每个数据源的实体类,例如:

package cn.juwatech.multidatasourcedemo.model.first;import javax.persistence.Entity;
import javax.persistence.GeneratedValue;
import javax.persistence.GenerationType;
import javax.persistence.Id;@Entity
public class FirstEntity {@Id@GeneratedValue(strategy = GenerationType.IDENTITY)private Long id;private String name;// 省略Getter和Setter方法
}
package cn.juwatech.multidatasourcedemo.model.second;import javax.persistence.Entity;
import javax.persistence.GeneratedValue;
import javax.persistence.GenerationType;
import javax.persistence.Id;@Entity
public class SecondEntity {@Id@GeneratedValue(strategy = GenerationType.IDENTITY)private Long id;private String description;// 省略Getter和Setter方法
}
8. 使用多数据源

在Service层或Controller层使用@Qualifier注解指定具体的数据源:

package cn.juwatech.multidatasourcedemo.service;import cn.juwatech.multidatasourcedemo.model.first.FirstEntity;
import cn.juwatech.multidatasourcedemo.model.second.SecondEntity;
import cn.juwatech.multidatasourcedemo.repository.first.FirstEntityRepository;
import cn.juwatech.multidatasourcedemo.repository.second.SecondEntityRepository;
import org.springframework.beans.factory.annotation.Autowired;
import org.springframework.beans.factory.annotation.Qualifier;
import org.springframework.stereotype.Service;
import org.springframework.transaction.annotation.Transactional;@Service
public class DataService {@Autowired@Qualifier("firstDataSource")private FirstEntityRepository firstRepository;@Autowired@Qualifier("secondDataSource")private SecondEntityRepository secondRepository;@Transactional(transactionManager = "firstTransactionManager")public void saveDataToFirstDB(FirstEntity entity) {firstRepository.save(entity);}@Transactional(transactionManager = "secondTransactionManager")public void saveDataToSecondDB(SecondEntity entity) {secondRepository.save(entity);}
}
9. 测试和部署

完成以上步骤后,可以启动Spring Boot应用程序,并测试多数据源的读写操作。确保每个数据源配置正确,并能够正常连接和操作数据库。

10. 总结

通过本文,我们详细介绍了如何在Spring Boot应用中配置和使用多数据源。从配置多个数据源的连接信息,到编写对应的Repository和实体类,再到在Service层使用@Qualifier注解指定数据源,我们逐步了解了如何处理复杂应用中的多数据源需求。

本文来自互联网用户投稿,该文观点仅代表作者本人,不代表本站立场。本站仅提供信息存储空间服务,不拥有所有权,不承担相关法律责任。如若转载,请注明出处:http://www.mzph.cn/diannao/37302.shtml

如若内容造成侵权/违法违规/事实不符,请联系多彩编程网进行投诉反馈email:809451989@qq.com,一经查实,立即删除!

相关文章

oracle with as 是什么并且怎么用

Oracle中的WITH AS语句&#xff0c;也被称为Common Table Expressions&#xff08;CTE&#xff09;&#xff0c;是一个用于定义临时结果集或视图的子句。这个临时结果集或视图只在当前的查询中存在&#xff0c;并且在查询完成后会被自动删除。使用WITH AS可以提高SQL语句的可读…

JavaWeb——MySQL:navicate客户端工具简单使用

目录 1. 连接 2. 新建数据库 3. 使用数据库 4. 新建表 5.使用表 6. 导出数据库 我这里是英文版&#xff0c;没有进行汉化。 1. 连接 点击左上角Connection&#xff0c;选择MySQL&#xff0c;&#xff08;我连接的是自己计算机上的数据库&#xff09;连接名输入&#x…

使用ScheduledExecutorService进行任务调度

使用ScheduledExecutorService进行任务调度 大家好&#xff0c;我是免费搭建查券返利机器人省钱赚佣金就用微赚淘客系统3.0的小编&#xff0c;也是冬天不穿秋裤&#xff0c;天冷也要风度的程序猿&#xff01; 在软件开发中&#xff0c;任务调度是一项重要的技术需求&#xff…

抖音开放平台运营同学联系我了,非常感谢

大家好&#xff0c;我是小悟 是怎么个事呢&#xff1f; 前几天在对接抖音开放平台&#xff0c;服务商代开发小程序里面的小程序备案&#xff0c;上传备案图片接口遇到了问题&#xff0c;具体的问题可详阅【抖音开放平台&#xff0c;这谁写的&#xff0c;要扣绩效吧】。 评论…

Zoom视频会议的虚拟背景功能:打造个性化会议体验

在远程工作和在线交流日益普及的今天&#xff0c;视频会议已成为连接人们的桥梁。Zoom视频会议软件因其出色的音视频质量和丰富的功能而广受欢迎。其中&#xff0c;虚拟背景功能是Zoom的一大亮点&#xff0c;它不仅能够保护用户隐私&#xff0c;还能为会议增添趣味性。本文将详…

Java编程基本功大揭秘 | 详解深入分析Java线程池源码和底层原理,掌握实战技巧【1】

详解深入分析Java线程池源码和底层原理 文章大纲引言Java线程池概念及重要性 ThreadPoolExecutor类的概述ThreadPoolExecutor类的基本功能和作用**基本功能****核心作用** ThreadPoolExecutor主要构造函数及其参数继承关系链功能介绍ThreadPoolExecutor 构造器构造器参数构造器…

c语言自动售货机

C语言编写的自动售货机程序可以模拟真实自动售货机的基本功能&#xff0c;例如选择商品、显示价格、付款和找零。下面是一个简单的示例代码&#xff0c;展示了一个基本的自动售货机程序&#xff1a; #include <stdio.h>// 商品结构体 typedef struct {char name[30];int…

破解对LabVIEW的偏见

LabVIEW被广泛应用于科学研究、工程测试和自动化控制领域&#xff0c;具有专业性和高效的开发能力。尽管有人对其存在偏见&#xff0c;认为不如C语言&#xff0c;但LabVIEW的图形化编程、强大集成能力、丰富社区支持和专业功能&#xff0c;使其在许多实际应用中表现出色。通过多…

Go语言环境安装

Go下载地址 哪个能用用哪个。 https://go.dev/ https://golang.google.cn/&#xff08;Golang官网的官方镜像&#xff09; Windows 使用.msi安装包安装 下载msi文件 安装 双击运行go1.22.4.windows-amd64.msi Next 勾选I accept the terms in the License Agreement&…

收藏 | SSL证书无效的原因和解决办法

当浏览器访问一个使用SSL证书保护的网站时&#xff0c;会检查其证书的有效性。如果发现证书存在问题&#xff0c;浏览器会显示“SSL证书无效”的警告信息&#xff0c;提醒用户存在潜在的安全风险。 “SSL证书无效”的警告可能会导致用户离开站点&#xff08;并且永远不会返回&…

MySQL高级-SQL优化-小结

文章目录 1、insert 优化2、主键优化3、order by 优化4、group by 优化5、limit 优化6、count 优化7、update 优化 1、insert 优化 insert&#xff1a;批量插入、手动控制事务、主键顺序插入 大批量插入&#xff1a;load data local infile 2、主键优化 主键长度尽量短、顺序插…

系统漏洞复现与勒索病毒

知识点&#xff1a;SMB漏洞介绍、漏洞复现流程、勒索病毒攻击与防护 渗透测试相关&#xff1a; 基本概念&#xff1a; 渗透测试就是利用我们所掌握的渗透知识&#xff0c;对网站进行一步一步的渗透&#xff0c;发现其中存在的漏洞和隐藏的风险&#xff0c;然后撰写一篇测试报…

FastAPI教程I

本文参考FastAPI教程https://fastapi.tiangolo.com/zh/tutorial 第一步 import uvicorn from fastapi import FastAPIapp FastAPI()app.get("/") async def root():return {"message": "Hello World"}if __name__ __main__:uvicorn.run(&quo…

GPT-4o模型到底有多强

近年来&#xff0c;人工智能技术突飞猛进&#xff0c;在自然语言处理&#xff08;NLP&#xff09;和计算机视觉等领域取得了令人瞩目的成就。OpenAI推出的GPT-4o模型作为最新一代的语言模型&#xff0c;进一步提升了AI的能力&#xff0c;尤其在文档分析、识图生文、文生图等功能…

elementUI的搭建使用过程

Element - The worlds most popular Vue UI framework 上面是elementUI的网站,进入网站 点击右上角的组件按钮 复制这段代码到你的项目终端:npm i element-ui -S 加载完成后即可使用elementUI网站中的组件,使用它们只需要复制组件下面的代码即可

Unity UGUI 实现简单两点连线功能

实现 记录鼠标点击位置为线段起点。 posStart Input.mousePosition; 创建一个Image 作为线段。 line new GameObject("line"); rtLine line.AddComponent<RectTransform>(); rtLine.pivot new Vector2(0, 0.5f); rtLine.localScale Vector3.one; img…

Linux 进程通信

1.什么是进程通信&#xff1f; 答&#xff1a;两个或多个进程实现数据层面的交互&#xff1b;但是因为进程的独立性&#xff0c;导致进程通信的成本较高&#xff1b; 2.为什么要通信&#xff1f; 答&#xff1a;多进程之间由协同的需求&#xff0c;所以通信&#xff1b;以下…

Java常用对象的快速初始化

在Java中&#xff0c;有多种方式来快速初始化各种常用对象&#xff0c;如字符串数组&#xff08;String[]&#xff09;&#xff0c;集合列表&#xff08;List&#xff09;&#xff0c;映射表&#xff08;Map&#xff09;&#xff0c;以及集合&#xff08;Set&#xff09;。不同…

动态服务管理的艺术:Eureka在服务扩展与收缩中的策略

动态服务管理的艺术&#xff1a;Eureka在服务扩展与收缩中的策略 在微服务架构中&#xff0c;服务的动态扩展和收缩是实现高可用性和弹性的关键。Eureka&#xff0c;作为Netflix开源的服务发现框架&#xff0c;提供了一套机制来处理服务实例的动态变化。本文将深入探讨Eureka如…

在操作系统中,background通常指的是运行于后台的进程或任务

在计算机中&#xff0c;"background"一词具有多种含义&#xff0c;以下是一些主要的解释和相关信息&#xff1a; 计算机视觉中的背景&#xff08;Background&#xff09;&#xff1a; 在计算机视觉中&#xff0c;background指的是图像或视频中的背景部分&#xff0c;…