当前位置: 首页 > news >正文

讲解下SpringBoot中MySql和MongoDB的配合使用

在Spring Boot中,MySQL和MongoDB可以配合使用,以充分发挥关系型数据库和非关系型数据库的优势。MySQL适合处理结构化数据,而MongoDB适合处理非结构化或半结构化数据。以下是如何在Spring Boot中同时使用MySQL和MongoDB的详细讲解。

1. 添加依赖

首先,在pom.xml中添加MySQL和MongoDB的依赖:

<dependencies><!-- Spring Boot Starter Data JPA for MySQL --><dependency><groupId>org.springframework.boot</groupId><artifactId>spring-boot-starter-data-jpa</artifactId></dependency><dependency><groupId>mysql</groupId><artifactId>mysql-connector-java</artifactId></dependency><!-- Spring Boot Starter Data MongoDB --><dependency><groupId>org.springframework.boot</groupId><artifactId>spring-boot-starter-data-mongodb</artifactId></dependency><!-- Other dependencies --><dependency><groupId>org.springframework.boot</groupId><artifactId>spring-boot-starter-web</artifactId></dependency>
</dependencies>

2. 配置数据源

application.propertiesapplication.yml中配置MySQL和MongoDB的连接信息。

application.properties 示例:
# MySQL 配置
spring.datasource.url=jdbc:mysql://localhost:3306/mydb
spring.datasource.username=root
spring.datasource.password=password
spring.datasource.driver-class-name=com.mysql.cj.jdbc.Driver
spring.jpa.hibernate.ddl-auto=update# MongoDB 配置
spring.data.mongodb.uri=mongodb://localhost:27017/mydb
application.yml 示例:
spring:datasource:url: jdbc:mysql://localhost:3306/mydbusername: rootpassword: passworddriver-class-name: com.mysql.cj.jdbc.Driverjpa:hibernate:ddl-auto: updatedata:mongodb:uri: mongodb://localhost:27017/mydb

3. 创建实体类和Repository

MySQL 实体类和Repository

创建一个MySQL实体类并使用JPA注解进行映射:

import javax.persistence.Entity;
import javax.persistence.GeneratedValue;
import javax.persistence.GenerationType;
import javax.persistence.Id;@Entity
public class User {@Id@GeneratedValue(strategy = GenerationType.IDENTITY)private Long id;private String name;private String email;// Getters and Setters
}

创建对应的JPA Repository:

import org.springframework.data.jpa.repository.JpaRepository;public interface UserRepository extends JpaRepository<User, Long> {
}
MongoDB 实体类和Repository

创建一个MongoDB实体类并使用MongoDB注解进行映射:

import org.springframework.data.annotation.Id;
import org.springframework.data.mongodb.core.mapping.Document;@Document
public class Product {@Idprivate String id;private String name;private double price;// Getters and Setters
}

创建对应的MongoDB Repository:

import org.springframework.data.mongodb.repository.MongoRepository;public interface ProductRepository extends MongoRepository<Product, String> {
}

4. 使用不同的Repository进行操作

在Service或Controller中,你可以分别使用UserRepositoryProductRepository来操作MySQL和MongoDB。

import org.springframework.beans.factory.annotation.Autowired;
import org.springframework.stereotype.Service;@Service
public class MyService {@Autowiredprivate UserRepository userRepository;@Autowiredprivate ProductRepository productRepository;public void addUser(User user) {userRepository.save(user);}public void addProduct(Product product) {productRepository.save(product);}public User getUserById(Long id) {return userRepository.findById(id).orElse(null);}public Product getProductById(String id) {return productRepository.findById(id).orElse(null);}
}

5. 事务管理

默认情况下,Spring Boot中的事务管理是基于JPA的,因此它只适用于MySQL。如果你需要在同一个事务中操作MySQL和MongoDB,可能需要使用分布式事务管理器(如JTA)或手动处理事务。

6. 总结

在Spring Boot中同时使用MySQL和MongoDB非常简单。通过配置不同的数据源,并使用对应的Repository,你可以轻松地在同一个应用中操作关系型和非关系型数据库。这种组合可以让你根据业务需求灵活选择存储方案,充分发挥两种数据库的优势。

http://www.lryc.cn/news/535679.html

相关文章:

  • 《手札·行业篇》开源Odoo MES系统与SKF Observer Phoenix API在化工行业的双向对接方案
  • 数据结构与算法之数组: LeetCode 905. 按奇偶排序数组 (Ts版)
  • 【STM32】HAL库Host MSC读写外部U盘及FatFS文件系统的USB Disk模式
  • docker nginx 配置文件详解
  • 如何实现华为云+deepseek?
  • 【学习笔记】计算机网络(三)
  • 稀土抑烟剂——为汽车火灾安全增添防线
  • Qt Pro、Pri、Prf
  • 基于AIOHTTP、Websocket和Vue3一步步实现web部署平台,无延迟控制台输出,接近原生SSH连接
  • 如何在MacOS上查看edge/chrome的扩展源码
  • 【xdoj-离散线上练习H】T234(C++)
  • Docker Desktop Windows 安装
  • springCloud-2021.0.9 之 GateWay 示例
  • JDK8 stream API用法汇总
  • windows生成SSL的PFX格式证书
  • 玩转大语言模型——使用Kiln AI可视化环境进行大语言模型微调数据合成
  • 2025 西湖论剑wp
  • FPGA 28 ,基于 Vivado Verilog 的呼吸灯效果设计与实现( 使用 Vivado Verilog 实现呼吸灯效果 )
  • 单片机简介
  • C++ 设计模式-桥接模式
  • 不小心删除服务[null]后,git bash出现错误
  • 16.React学习笔记.React更新机制
  • 【Elasticsearch】词干提取(Stemming)
  • 【AI论文】10亿参数大语言模型能超越405亿参数大语言模型吗?重新思考测试时计算最优缩放
  • 【设计模式】【行为型模式】状态模式(State)
  • PostgreSQL错误: 编码“UTF8“的字符0x0xe9 0x94 0x99在编码“WIN1252“没有相对应值
  • Mac ARM 架构的命令行(终端)中,删除整行的快捷键是:Ctrl + U
  • Vue2下判断有新消息来时以站内信方式在页面右下角弹出
  • AI语言模型的技术之争:DeepSeek与ChatGPT的架构与训练揭秘
  • 网络安全中的account和audit区别