在SpringBoot中优雅整合MongoDB——让你的数据存储更灵活

文章目录

在现代开发中,关系型数据库如MySQL虽然常见,但在某些场景下,非关系型数据库(NoSQL)如MongoDB更能满足需求。尤其是在需要存储灵活的数据结构时,MongoDB的文档模型比起传统的表格结构更加适合。今天,我将带你一步步整合SpringBoot与MongoDB,让你能轻松驾驭这个强大的数据库。

一、两种整合方式:MongoTemplate 与 MongoRepository

Spring Data MongoDB 提供了两种主要的操作MongoDB的方式:

  1. MongoTemplate:提供了更细粒度的控制,适合复杂查询和操作。
  2. MongoRepository:基于Spring Data Repository的简化操作,更加符合Spring Data的风格,适合CRUD操作。

我们将分别展示如何使用这两种方式来操作MongoDB。

二、准备工作

在开始编写代码之前,我们需要进行一些基本的项目配置。

第一步:创建SpringBoot项目并引入MongoDB依赖

首先,我们创建一个SpringBoot项目,并在pom.xml文件中引入MongoDB相关的依赖:

xml 复制代码
<dependencies>
    <!-- Spring Web Starter -->
    <dependency>
        <groupId>org.springframework.boot</groupId>
        <artifactId>spring-boot-starter-web</artifactId>
    </dependency>

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

    <!-- Lombok -->
    <dependency>
        <groupId>org.projectlombok</groupId>
        <artifactId>lombok</artifactId>
    </dependency>

    <!-- Testing Starter -->
    <dependency>
        <groupId>org.springframework.boot</groupId>
        <artifactId>spring-boot-starter-test</artifactId>
        <scope>test</scope>
    </dependency>
</dependencies>
第二步:配置MongoDB连接

接下来,我们在application.yml文件中配置MongoDB的连接信息:

yaml 复制代码
spring:
  data:
    mongodb:
      database: daijia
      host: 192.168.2.129
      port: 27017
第三步:创建实体类

我们创建一个User实体类,它将映射到MongoDB中的user集合。

java 复制代码
@Data
@Document("user")
public class User {

    @Id
    private ObjectId id;
    
    private String name;
    private Integer age;
    private String email;
    private Date createDate;
}

三、使用MongoRepository进行操作

1. 创建Repository接口

首先,我们创建一个接口UserRepository,它继承自MongoRepository

java 复制代码
public interface UserRepository extends MongoRepository<User, ObjectId> {
}
2. 编写测试类

在测试类中,我们可以轻松地进行CRUD操作:

java 复制代码
@SpringBootTest
public class MongoRepositoryTest {

    @Autowired
    private UserRepository userRepository;

    // 添加用户
    @Test
    public void add() {
        User user = new User();
        user.setName("mary");
        user.setAge(30);
        user.setCreateDate(new Date());
        userRepository.save(user);
    }

    // 查询所有用户
    @Test
    public void findAll() {
        List<User> list = userRepository.findAll();
        System.out.println(list);
    }

    // 根据ID查询用户
    @Test
    public void testFindById() {
        Optional<User> optional = userRepository.findById(new ObjectId("666a9a85f5294513720647ff"));
        optional.ifPresent(System.out::println);
    }

    // 条件查询 + 排序
    @Test
    public void testFindCondition() {
        User user = new User();
        user.setAge(20);
        Example<User> example = Example.of(user);
        Sort sort = Sort.by(Sort.Direction.DESC, "name");
        List<User> list = userRepository.findAll(example, sort);
        System.out.println(list);
    }

    // 分页查询
    @Test
    public void testPage() {
        PageRequest pageable = PageRequest.of(0, 2);
        Page<User> page = userRepository.findAll(pageable);
        System.out.println(page.getContent());
    }

    // 更新用户信息
    @Test
    public void testUpdateUser() {
        Optional<User> optional = userRepository.findById(new ObjectId("64eee9dff317c823c62b4faf"));
        optional.ifPresent(user -> {
            user.setAge(100);
            userRepository.save(user);
            System.out.println(user);
        });
    }

    // 删除用户
    @Test
    public void testDeleteUser() {
        userRepository.deleteById(new ObjectId("64eee9dff317c823c62b4faf"));
    }
}

四、使用MongoTemplate进行操作

如果你需要更灵活的操作,可以选择使用MongoTemplate

1. 使用示例

同样,我们编写一个测试类来演示如何使用MongoTemplate进行操作:

java 复制代码
@SpringBootTest
public class MongoTemplateTest {

    @Autowired
    private MongoTemplate mongoTemplate;

    // 添加用户
    @Test
    public void add() {
        User user = new User();
        user.setName("test");
        user.setAge(20);
        user.setCreateDate(new Date());
        mongoTemplate.insert(user);
    }

    // 查询所有用户
    @Test
    public void findAll() {
        List<User> list = mongoTemplate.findAll(User.class);
        list.forEach(System.out::println);
    }

    // 根据ID查询用户
    @Test
    public void testFindId() {
        User user = mongoTemplate.findById("666a9b5e9a3653796627bb3c", User.class);
        System.out.println(user);
    }

    // 条件查询
    @Test
    public void testCondition() {
        Criteria criteria = Criteria.where("name").is("test").and("age").is(20);
        Query query = new Query(criteria);
        List<User> list = mongoTemplate.find(query, User.class);
        System.out.println(list);
    }

    // 分页查询
    @Test
    public void testPage() {
        Query query = new Query();
        List<User> list = mongoTemplate.find(query.skip(0).limit(2), User.class);
        list.forEach(System.out::println);
    }

    // 更新用户信息
    @Test
    public void testUpdateUser() {
        Criteria criteria = Criteria.where("_id").is("64eeeae31711344f35635788");
        Query query = new Query(criteria);
        Update update = new Update();
        update.set("name", "zhangsan");
        update.set("age", 99);
        UpdateResult result = mongoTemplate.upsert(query, update, User.class);
        System.out.println(result.getModifiedCount());
    }

    // 删除用户
    @Test
    public void testRemove() {
        Criteria criteria = Criteria.where("_id").is("64eeeae31711344f35635788");
        Query query = new Query(criteria);
        DeleteResult result = mongoTemplate.remove(query, User.class);
        System.out.println(result.getDeletedCount());
    }
}

五、总结

通过这篇博客,你已经了解了如何在SpringBoot中整合MongoDB,并通过两种不同的方式(MongoRepository和MongoTemplate)进行数据操作。对于简单的CRUD操作,MongoRepository可以让你的代码更加简洁;而MongoTemplate则在你需要更复杂的查询或更新操作时提供了更大的灵活性。

相关推荐
码农水水1 分钟前
米哈游Java面试被问:Shenandoah GC的Brooks Pointer实现机制
java·开发语言·jvm·spring boot·redis·安全·面试
九皇叔叔5 分钟前
【06】SpringBoot3 MybatisPlus 修改(Mapper)
java·spring boot·mybatis·mybatisplus
mc_故事与你16 分钟前
前后端分离项目(springboot+vue+mybatis)-教学文档(SpringBoot3+Vue2)-4 (正在编写)
vue.js·spring boot·mybatis
麦聪聊数据17 分钟前
LiveOps事故零容忍:游戏行业数据库的细粒度权限管控与审计实践
运维·数据库·后端·sql
shepherd12630 分钟前
深度剖析SkyWalking:从内核原理到生产级全链路监控实战
分布式·后端·skywalking
橘子师兄32 分钟前
C++AI大模型接入SDK—Genimi接入封装
c++·人工智能·后端
码农水水36 分钟前
大疆Java面试被问:使用Async-profiler进行CPU热点分析和火焰图解读
java·开发语言·jvm·数据结构·后端·面试·职场和发展
我真的是大笨蛋43 分钟前
MVCC解析
java·数据库·spring boot·sql·mysql·设计模式·设计规范
秃头续命码农人1 小时前
谈谈对Spring、Spring MVC、SpringBoot、SpringCloud,Mybatis框架的理解
java·spring boot·spring·mvc·maven·mybatis
ahauedu1 小时前
SpringBoot 3.5.10引入springdoc-openapi-starter-webmvc-ui版本
java·spring boot·后端