【数据库系列】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 应用中使用。你可以根据自己的需求,进一步扩展和优化这些基础操作。希望这篇文章能对你有所帮助!

相关推荐
枫叶丹417 小时前
【Qt开发】Qt窗口(九) -> QFontDialog 字体对话框
c语言·开发语言·数据库·c++·qt
w_t_y_y1 天前
Nginx Plus
运维·数据库·nginx
川贝枇杷膏cbppg1 天前
dm_unknown_202512.log:达梦数据库 “未分类日志“
数据库·oracle
计算机毕设VX:Fegn08951 天前
计算机毕业设计|基于springboot + vue图书商城系统(源码+数据库+文档)
java·数据库·vue.js·spring boot·后端·课程设计
求学中--1 天前
MySQL 数据库完整操作命令与使用指南
数据库·sql·mysql·oracle
DKunYu1 天前
误删数据库表导致出现1146报错
数据库
惜分飞1 天前
sql server 事务日志备份异常恢复案例---惜分飞
前端·数据库·php
hhzz1 天前
Spring Boot整合Activiti的项目中实现抄送功能
java·spring boot·后端
sunddy_x1 天前
MySQL入门
数据库·mysql
愿你天黑有灯下雨有伞1 天前
实战演练:如何在Spring Boot项目中优雅地使用参数校验
spring boot