百度360必应搜狗淘宝本站头条
当前位置:网站首页 > 技术文章 > 正文

详细介绍一下Spring Boot3中如何使用MongoDB数据库?

wuantov 2025-07-19 23:13 12 浏览

MongoDB是一个基于文档的开源的NoSQL数据库,被广泛应用于高并发、高扩展可快速迭代开发的应用场景中,与传统的关系型数据库有所不同的是,MongoDB的数据存储并不需要表、行和列等数据存储结构,MongoDB的数据存储是以文档(Document)的方式进行的存储。所以在灵活性和高可用性上成为了现代很多应用数据库开发的首选。而下面我们就来介绍一下如何在Spring Boot3中集成并且使用MongoDB。

添加依赖

在Spring Boot3中使用MongoDB与Spring Boot2中的集成步骤类似,可以通过Spring Data MongoDB来简化MongoDB数据库的操作。首先,就需要我们引入Spring Data MongoDB的依赖,如下所示。

<dependencies>
    <dependency>
        <groupId>org.springframework.boot</groupId>
        <artifactId>spring-boot-starter-data-mongodb</artifactId>
    </dependency>
</dependencies>

依赖添加完成之后,接下来我们就需要配置与MongoDB数据库的连接参数,如下所示。

spring.data.mongodb.host=localhost
spring.data.mongodb.port=27017
spring.data.mongodb.database=mydatabase
spring.data.mongodb.username=myuser
spring.data.mongodb.password=mypassword

或者可以使用Yaml的方式来进行配置

spring:
  data:
    mongodb:
      uri: mongodb://localhost:27017/mydatabase

创建模型类

通过Spring Data MongoDB来整合MongoDB的时候,我们可以通过@Document注解来映射MongoDB中的集合与Java对象之间的关系,如下所示,创建一个模型类并且通过@Document注解来进行映射。

import org.springframework.data.annotation.Id;
import org.springframework.data.mongodb.core.mapping.Document;

@Document(collection = "users")
public class User {

    @Id
    private String id;
    private String name;
    private String email;

    // getters and setters
}

映射完成之后,接下来就可以利用Spring Data MongoDB提供的CURD的操作来完成对于数据的CRUD操作,我们需要继承MongoRepository接口来实现相关的操作。

import org.springframework.data.mongodb.repository.MongoRepository;

public interface UserRepository extends MongoRepository<User, String> {
    // 可以自定义查询方法
    User findByName(String name);
}

接下来,我们就可以在服务类或者是在控制器中直接使用这个UserRepository进行操作,如下所示。

import org.springframework.beans.factory.annotation.Autowired;
import org.springframework.stereotype.Service;

@Service
public class UserService {

    @Autowired
    private UserRepository userRepository;

    public User createUser(String name, String email) {
        User user = new User();
        user.setName(name);
        user.setEmail(email);
        return userRepository.save(user);
    }

    public User getUserByName(String name) {
        return userRepository.findByName(name);
    }
}

测试接口

我们可以定义Controller层的RESTFul接口来测试MongoDB对于数据CRUD的操作功能。

@RestController
public class UserController {

    @Autowired
    private UserService userService;

    @GetMapping("/createUser")
    public String createUser(@RequestParam String name, @RequestParam String email) {
        userService.createUser(name, email);
        return "User created successfully!";
    }

    @GetMapping("/getUser")
    public User getUser(@RequestParam String name) {
        return userService.getUserByName(name);
    }
}

总结

上面我们介绍了通过Spring Data MongoDB来实现对于MongoDB的CRUD的操作,当然除了上面提供的这种方式之外MongoDB还提供了其他交互方式,例如可以通过MongoTemplate来进行精细化的数据操作,或者是对数据进行一些复杂的查询操作。如果需要有一些自定义的操作的话还可以通过原生驱动的方式来进行编码。如果想去做一些响应式的开发MongoDB也提供了Reactive MongoDB进行响应式的编程。当然,每种方式都适合于不同的数据处理场景,我们可以根据自己的实际需求来选择合适的技术。

相关推荐

SQL关联各种JOIN傻傻分不清楚,读这一篇就够了

在关系型数据库中支持多表关联,不同场景下通过不同join方式让分布在不同表中的数据呈现在同一个结果里。熟练使用sql联合查询是日常开发的基础工作。为了方便演示讲解,假设有两个表,一张是保存学生踢足球的...

MyBatis的SQL执行流程不清楚?看完这一篇就够了

推荐学习真香警告!Alibaba珍藏版mybatis手写文档,刷起来全网独家的“MySQL高级知识”集合,骨灰级收藏,手慢则无前言MyBatis可能很多人都一直在用,但是MyBatis的SQL执行...

SQL优化这十条,面试的时候你都答对了吗?

尽量不要在要给在SQL语句的where子句中使用函数,这样会使索引失效。如果已经确定查询结果只有一条数据(当表中数据的该字段是唯一的),在查询SQL末尾增加limit1,这样MySQL的查询执行引...

SQL查询Excel结果数据还可这样输出到窗体控件ListBox和ListView

上一期作品,我们分享了通过SQL查询Excel的结果数据输出到Excel自身的工作表区域。大家估计应该感觉到了SQL查询的强大功能,它对精确或模糊查询均无畏惧,优点是查询检索效率高,将查询结果输出的形...

数据库|SQLServer数据库:模糊查询的三种情况

哈喽,你好啊,我是雷工!就是字面意思,当数据库的查询条件并不是十分具体时就用到模糊查询,比如查询姓氏为雷的人名,就需要从姓名列模糊查询。01like关键字查询当使用like关键字进行查询时,字段中的...

数据库教程-SQL Server多条件模糊查询

表单查询是以数据存储管理为基础的信息管理系统各业务功能实现的基础,也是数据库CRUD操作的重点与难点,尤其是多表连接查询、条件查询、分组查询、聚合函数等的综合应用。本文以某一比赛样式要求为基础,对数据...

如何利用教育网站源码成功搭建在线教育网站

如今是一个信息化时代,人们都想接受各种各样的教育,在线教育也就因此发展了起来,并且逐渐成为了一种趋势。而成熟的在线教育网站皆是由高质量的教育网站源码搭建而成的。如何利用教育网站源码成功搭建在线教育网站...

宝塔搭建WordPress跨境电商外贸商城模板汉化woodmart7.5.1源码

大家好啊,欢迎来到web测评。本期给大家带来一套php开发的WoodmartV7.5.1汉化主题|跨境电商|外贸商城|产品展示网站模板WordPress主题,是wordpress开发的。上次是谁要的系...

小狐狸ChatGPT付费创作系统V2.4.7全开源版 (vue全开源端)

测试环境:Nginx1.20+PHP7.4+MySQL5.7本版本为官方的最新开源包对应V2.4.7版本,包含了前后端所有开源包,是目前最新全开源版本,需要二开的这部分朋友也有选择了,如果不需要二...

php宝塔搭建部署thinkphp红色大气装修公司官网php源码

大家好啊,欢迎来到web测评。本期给大家带来一套php开发的thinkphp红色大气装修公司官网源码,上次是谁要的系统项目啊,帮你找到了,还说不会搭建,让我帮忙录制一期教程,趁着今天有空,简单的录制测...

php宝塔搭建免登录积分商城系统php源码

大家好啊,欢迎来到web测评。本期给大家带来一套php开发的免登录积分商城系统php源码,上次是谁要的系统项目啊,帮你找到了,还说不会搭建,让我帮忙录制一期教程,趁着今天有空,简单的录制测试了一下,部...

零代码搭建接口收费平台——接口大师YesApi

主流的API接口收费模式目前各大API接口平台,采用的收费模式主可以分为:免费接口、免费试用、接口流量套餐、先充值后按量计费的模式。例如,聚合数据的API收费模式是:按接口流量套餐。例如身份证二要素...

php宝塔搭建部署实战抽奖系统开源php源码

大家好啊,我是测评君,欢迎来到web测评。本期给大家带来一套抽奖系统开源php源码。感兴趣的朋友可以自行下载学习。技术架构PHP5.4+nginx+mysql5.7+JS+CSS+...

【推荐】一款开源个人与企业私有化部署使用的在线知识库管理平台

如果您对源码&技术感兴趣,请点赞+收藏+转发+关注,大家的支持是我分享最大的动力!!!项目介绍zyplayer-doc是一款基于Java+Vue开源、专注于个人与企业私有化部署使用的在线知识库管...

网上的付费文档无法下载?这几个方法10秒搞定,任意免费复制

工作或者学习过程中,我们很多时候需要在网上找资料,但是想要的资料却要付费或者提示无法下载怎么办?别怕,这几个方法,让你10秒就能搞定付费文档,任意复制。1.打印界面复制遇到文档需要付费或者无法复制的...