【数据库系列】MongoTemplate 基本入门:MongoDB 的增删改查

MongoDB 是一种流行的 NoSQL 数据库,适合存储大量的非结构化数据。在 Spring 框架中,MongoTemplate 提供了一种方便的方式来与 MongoDB 进行交互,支持基本的增删改查操作。本文将详细介绍 MongoTemplate 的基本用法,包含语法介绍和具体的使用示例。

1. 环境准备

1.1 依赖配置

首先,确保你已经创建了一个 Spring Boot 项目,并在 pom.xml 中添加了 MongoDB 的依赖:

xml 复制代码
<dependency>
    <groupId>org.springframework.boot</groupId>
    <artifactId>spring-boot-starter-data-mongodb</artifactId>
</dependency>

1.2 数据库配置

src/main/resources/application.properties 中,配置 MongoDB 的连接信息:

properties 复制代码
spring.data.mongodb.uri=mongodb://localhost:27017/testdb

2. MongoTemplate 的基本用法

2.1 创建 MongoTemplate Bean

在 Spring Boot 中,MongoTemplate 通常作为 Bean 注入使用。你可以在主应用类中或配置类中创建它:

java 复制代码
import org.springframework.context.annotation.Bean;
import org.springframework.context.annotation.Configuration;
import org.springframework.data.mongodb.MongoDatabaseFactory;
import org.springframework.data.mongodb.core.MongoTemplate;

@Configuration
public class MongoConfig {
    @Bean
    public MongoTemplate mongoTemplate(MongoDatabaseFactory mongoDatabaseFactory) {
        return new MongoTemplate(mongoDatabaseFactory);
    }
}

2.2 实体类定义

接下来,定义一个实体类 User,用于存储用户信息:

java 复制代码
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
    public String getId() {
        return id;
    }
    public void setId(String id) {
        this.id = id;
    }
    public String getName() {
        return name;
    }
    public void setName(String name) {
        this.name = name;
    }
    public String getEmail() {
        return email;
    }
    public void setEmail(String email) {
        this.email = email;
    }
}

3. 基本操作示例

3.1 增加用户(Create)

使用 MongoTemplateinsert 方法插入用户信息:

java 复制代码
import org.springframework.beans.factory.annotation.Autowired;
import org.springframework.data.mongodb.core.MongoTemplate;
import org.springframework.stereotype.Service;

@Service
public class UserService {
    @Autowired
    private MongoTemplate mongoTemplate;

    public User addUser(User user) {
        return mongoTemplate.insert(user);
    }
}

3.2 查询用户(Read)

使用 find 方法查询用户信息:

java 复制代码
import org.springframework.data.mongodb.core.query.Criteria;
import org.springframework.data.mongodb.core.query.Query;

public User getUserById(String id) {
    return mongoTemplate.findById(id, User.class);
}

public List<User> getAllUsers() {
    return mongoTemplate.findAll(User.class);
}

public User getUserByEmail(String email) {
    Query query = new Query();
    query.addCriteria(Criteria.where("email").is(email));
    return mongoTemplate.findOne(query, User.class);
}

3.3 更新用户(Update)

使用 save 方法更新用户信息:

java 复制代码
public User updateUser(User user) {
    return mongoTemplate.save(user);
}

3.4 删除用户(Delete)

使用 remove 方法删除用户信息:

java 复制代码
public void deleteUser(String id) {
    Query query = new Query();
    query.addCriteria(Criteria.where("id").is(id));
    mongoTemplate.remove(query, User.class);
}

4. 完整示例

将上述代码整合到一个完整的服务类中:

java 复制代码
import org.springframework.beans.factory.annotation.Autowired;
import org.springframework.data.mongodb.core.MongoTemplate;
import org.springframework.data.mongodb.core.query.Criteria;
import org.springframework.data.mongodb.core.query.Query;
import org.springframework.stereotype.Service;

import java.util.List;

@Service
public class UserService {
    @Autowired
    private MongoTemplate mongoTemplate;

    public User addUser(User user) {
        return mongoTemplate.insert(user);
    }

    public User getUserById(String id) {
        return mongoTemplate.findById(id, User.class);
    }

    public List<User> getAllUsers() {
        return mongoTemplate.findAll(User.class);
    }

    public User getUserByEmail(String email) {
        Query query = new Query();
        query.addCriteria(Criteria.where("email").is(email));
        return mongoTemplate.findOne(query, User.class);
    }

    public User updateUser(User user) {
        return mongoTemplate.save(user);
    }

    public void deleteUser(String id) {
        Query query = new Query();
        query.addCriteria(Criteria.where("id").is(id));
        mongoTemplate.remove(query, User.class);
    }
}

5. 测试 API

可以通过构建 REST 控制器来测试以上服务。例如,创建一个 UserController

java 复制代码
import org.springframework.beans.factory.annotation.Autowired;
import org.springframework.http.ResponseEntity;
import org.springframework.web.bind.annotation.*;

import java.util.List;

@RestController
@RequestMapping("/api/users")
public class UserController {
    @Autowired
    private UserService userService;

    @PostMapping
    public ResponseEntity<User> createUser(@RequestBody User user) {
        return ResponseEntity.ok(userService.addUser(user));
    }

    @GetMapping("/{id}")
    public ResponseEntity<User> getUser(@PathVariable String id) {
        return ResponseEntity.ok(userService.getUserById(id));
    }

    @GetMapping
    public ResponseEntity<List<User>> getAllUsers() {
        return ResponseEntity.ok(userService.getAllUsers());
    }

    @PutMapping
    public ResponseEntity<User> updateUser(@RequestBody User user) {
        return ResponseEntity.ok(userService.updateUser(user));
    }

    @DeleteMapping("/{id}")
    public ResponseEntity<Void> deleteUser(@PathVariable String id) {
        userService.deleteUser(id);
        return ResponseEntity.noContent().build();
    }
}

结论

通过本文的介绍,你已经掌握了使用 MongoTemplate 与 MongoDB 进行基本的增删改查操作。MongoTemplate 提供了一个灵活而强大的方式来操作 MongoDB 数据库,非常适合在 Spring 应用中使用。你可以根据自己的需求,进一步扩展和优化这些基础操作。希望这篇文章能对你有所帮助!

相关推荐
IT毕设实战小研2 小时前
基于Spring Boot 4s店车辆管理系统 租车管理系统 停车位管理系统 智慧车辆管理系统
java·开发语言·spring boot·后端·spring·毕业设计·课程设计
wyiyiyi2 小时前
【Web后端】Django、flask及其场景——以构建系统原型为例
前端·数据库·后端·python·django·flask
一只爱撸猫的程序猿3 小时前
使用Spring AI配合MCP(Model Context Protocol)构建一个"智能代码审查助手"
spring boot·aigc·ai编程
天宇_任3 小时前
Mysql数据库迁移到GaussDB注意事项
数据库·mysql·gaussdb
甄超锋3 小时前
Java ArrayList的介绍及用法
java·windows·spring boot·python·spring·spring cloud·tomcat
武昌库里写JAVA5 小时前
JAVA面试汇总(四)JVM(一)
java·vue.js·spring boot·sql·学习
xiep14383335105 小时前
Ubuntu 安装带证书的 etcd 集群
数据库·etcd
Java小白程序员6 小时前
Spring Framework:Java 开发的基石与 Spring 生态的起点
java·数据库·spring
Pitayafruit6 小时前
Spring AI 进阶之路03:集成RAG构建高效知识库
spring boot·后端·llm
老虎06277 小时前
数据库基础—SQL语句总结及在开发时
数据库·sql·oracle