Java如何实现MongoDB的CRUD操作

来源:IPIPP.com作者:头衔:全栈工程师
导读:本期聚焦于小伙伴创作的《Java如何实现MongoDB的CRUD操作》,敬请观看详情,探索知识的价值。以下视频、文章将为您系统阐述其核心内容与价值。如果您觉得《Java如何实现MongoDB的CRUD操作》有用,将其分享出去将是对创作者最好的鼓励。

MongoDB作为常用的非关系型数据库,在Java项目中的应用非常广泛,掌握其CRUD操作是开发者的必备技能。下面我们先来看整体操作的准备工作和具体实现。

Java如何实现MongoDB的CRUD操作

一、环境准备

1. 依赖引入

如果使用原生MongoDB Java驱动,在Maven项目的pom.xml中添加以下依赖:

<dependency>
    <groupId>org.mongodb</groupId>
    <artifactId>mongodb-driver-sync</artifactId>
    <version>4.9.0</version>
</dependency>

如果使用Spring Data MongoDB,添加对应 starter 依赖:

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

2. 连接配置

原生驱动连接示例:

// 连接本地MongoDB服务,默认端口27017
MongoClient mongoClient = MongoClients.create("mongodb://127.0.0.1:27017");
// 获取指定数据库,若不存在则自动创建
MongoDatabase database = mongoClient.getDatabase("test_db");
// 获取指定集合,若不存在则自动创建
MongoCollection<Document> collection = database.getCollection("user_collection");

Spring Boot配置在application.yml中:

spring:
  data:
    mongodb:
      host: 127.0.0.1
      port: 27017
      database: test_db

二、原生驱动CRUD实现

1. 插入操作(Create)

单条插入:

Document user = new Document();
user.append("name", "张三");
user.append("age", 25);
user.append("hobby", "篮球");
// 插入单条文档
collection.insertOne(user);

批量插入:

List<Document> userList = new ArrayList<>();
userList.add(new Document("name", "李四").append("age", 22).append("hobby", "足球"));
userList.add(new Document("name", "王五").append("age", 28).append("hobby", "阅读"));
// 批量插入文档
collection.insertMany(userList);

2. 查询操作(Read)

查询所有文档:

// 查询集合中所有文档
FindIterable<Document> documents = collection.find();
for (Document doc : documents) {
    System.out.println(doc.toJson());
}

条件查询,比如查询年龄大于23岁的用户:

// 构建查询条件:age > 23
Bson filter = Filters.gt("age", 23);
FindIterable<Document> result = collection.find(filter);
for (Document doc : result) {
    System.out.println(doc.toJson());
}

3. 更新操作(Update)

更新单条匹配文档,比如把张三的年龄改为26:

// 匹配条件:name为张三
Bson updateFilter = Filters.eq("name", "张三");
// 更新内容:设置age为26
Bson update = Updates.set("age", 26);
// 更新第一条匹配的文档
collection.updateOne(updateFilter, update);

批量更新,比如把所有年龄小于25的用户爱好改为跑步:

Bson batchFilter = Filters.lt("age", 25);
Bson batchUpdate = Updates.set("hobby", "跑步");
// 更新所有匹配的文档
collection.updateMany(batchFilter, batchUpdate);

4. 删除操作(Delete)

删除单条匹配文档:

Bson deleteFilter = Filters.eq("name", "王五");
// 删除第一条匹配的文档
collection.deleteOne(deleteFilter);

批量删除:

Bson batchDeleteFilter = Filters.lt("age", 20);
// 删除所有匹配的文档
collection.deleteMany(batchDeleteFilter);

三、Spring Data MongoDB实现CRUD

1. 定义实体类

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

@Document(collection = "user_collection")
public class User {
    @Id
    private String id;
    private String name;
    private Integer age;
    private String hobby;

    // 省略getter、setter和toString方法
}

2. 定义Repository接口

import org.springframework.data.mongodb.repository.MongoRepository;
import java.util.List;

public interface UserRepository extends MongoRepository<User, String> {
    // 自定义查询方法,根据名字查询
    List<User> findByName(String name);
    // 自定义查询方法,根据年龄大于指定值查询
    List<User> findByAgeGreaterThan(Integer age);
}

3. 业务层调用示例

import org.springframework.beans.factory.annotation.Autowired;
import org.springframework.stereotype.Service;
import java.util.List;

@Service
public class UserService {
    @Autowired
    private UserRepository userRepository;

    // 插入用户
    public User saveUser(User user) {
        return userRepository.save(user);
    }

    // 查询所有用户
    public List<User> getAllUsers() {
        return userRepository.findAll();
    }

    // 根据名字查询用户
    public List<User> getUsersByName(String name) {
        return userRepository.findByName(name);
    }

    // 更新用户
    public User updateUser(User user) {
        return userRepository.save(user);
    }

    // 删除用户
    public void deleteUser(String id) {
        userRepository.deleteById(id);
    }
}

四、注意事项

  • 操作完成后要及时关闭MongoClient连接,避免资源泄露,Spring Data MongoDB会自动管理连接生命周期
  • MongoDB的文档字段是动态可扩展的,不需要提前定义所有字段,新增字段直接插入即可
  • 条件查询时如果字段不存在,默认会返回空结果,不会报错
  • 批量操作如果数据量较大,建议分批次处理,避免单次操作占用过多内存

通过以上两种方式,开发者可以根据项目需求选择合适的Java操作MongoDB的方案,原生驱动更灵活,Spring Data MongoDB更便捷,都能满足日常CRUD开发需求。

JavaMongoDBCRUDSpring_Data_MongoDB修改时间:2026-05-25 00:41:17

免责声明:已尽一切努力确保本网站所含信息的准确性。网站部分内容来源于网络或由用户自行发表,内容观点不代表本站立场。本站是个人网站免费分享,内容仅供个人学习、研究或参考使用,如内容中引用了第三方作品,其版权归原作者所有。若内容触犯了您的权益,请联系我们进行处理。
内容垂直聚焦
专注技术核心技术栏目,确保每篇文章深度聚焦于实用技能。从代码技巧到架构设计,为用户提供无干扰的纯技术知识沉淀,精准满足专业提升需求。
知识结构清晰
覆盖从开发到部署的全链路。前端、网络、数据库、服务器、建站、系统层层递进,构建清晰学习路径,帮助用户系统化掌握网站开发与运维所需的核心技术栈。
深度技术解析
拒绝泛泛而谈,深入技术细节与实践难点。无论是数据库优化还是服务器配置,均结合真实场景与代码示例进行剖析,致力于提供可直接应用于工作的解决方案。
专业领域覆盖
精准对应开发生命周期。从前端界面到后端逻辑,从数据库操作到服务器运维,形成完整闭环,一站式满足全栈工程师和运维人员的技术需求。
即学即用高效
内容强调实操性,步骤清晰、代码完整。用户可根据教程直接复现和应用于自身项目,显著缩短从学习到实践的距离,快速解决开发中的具体问题。
持续更新保障
专注既定技术方向进行长期、稳定的内容输出。确保各栏目技术文章持续更新迭代,紧跟主流技术发展趋势,为用户提供经久不衰的学习价值。