SpringBoot集成MongoDB

本文介绍了如何在SpringBoot应用中集成MongoDB,包括添加依赖、配置连接参数、创建实体类,并展示了如何使用MongoTemplate进行CRUD操作。通过实例演示了插入、查询、更新和删除数据的方法。

SpringBoot集成MongoDB

pom文件


<!-- 继承Spring boot -->
<parent>
    <groupId>org.springframework.boot</groupId>
    <artifactId>spring-boot-starter-parent</artifactId>
    <version>2.1.5.RELEASE</version>
</parent>

<dependencies>
    <dependency>
        <groupId>org.springframework.boot</groupId>
        <artifactId>spring-boot-starter-web</artifactId>
    </dependency>
    <dependency>
        <groupId>org.springframework.boot</groupId>
        <artifactId>spring-boot-starter-test</artifactId>
    </dependency>
    <dependency>
        <groupId>org.springframework.boot</groupId>
        <artifactId>spring-boot-starter-data-mongodb</artifactId>
    </dependency>
    <!-- lombok -->
    <dependency>
        <groupId>org.projectlombok</groupId>
        <artifactId>lombok</artifactId>
        <version>1.18.8</version>
    </dependency>
</dependencies>

配置文件:application.properties

spring.data.mongodb.username=username
spring.data.mongodb.password=pwd
spring.data.mongodb.authentication-database=admin
spring.data.mongodb.database=yyy
spring.data.mongodb.port=27017
spring.data.mongodb.host=192.168.200.130

实体类

实体类添加注解@Document与mongodb中的集合对应
import lombok.Data;
import org.springframework.data.annotation.Id;
import org.springframework.data.mongodb.core.mapping.Document;

import java.math.BigDecimal;
import java.util.Date;

/**
 * APP评论信息
 */
@Data
@Document("comment")
public class Comment {
	/**
     * id
     */
    private String id;

    /**
     * 用户ID
     */
    private Integer authorId;

    /**
     * 用户昵称
     */
    private String authorName;
}

使用时,直接注入mongoTemplate

    @Autowired
    private MongoTemplate mongoTemplate; 

CRUD

import org.junit.Test;
import org.junit.runner.RunWith;
import org.springframework.beans.factory.annotation.Autowired;
import org.springframework.boot.test.context.SpringBootTest;
import org.springframework.data.domain.PageRequest;
import org.springframework.data.domain.Pageable;
import org.springframework.data.domain.Sort;
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.data.mongodb.core.query.Update;
import org.springframework.test.context.junit4.SpringRunner;

import java.util.List;

@SpringBootTest(classes = MongoApplication.class)
@RunWith(SpringRunner.class)
public class MongoTest {

   @Autowired
   private MongoTemplate mongoTemplate;

   //添加
   @Test
   public void testCreate() {
       for (int i = 0; i < 10; i++) {
           Comment comment = new Comment();
           comment.setContent("这是一个评论");
           comment.setLikes(20+i);
           mongoTemplate.insert(comment);
       }

   }

   //查询一个
   @Test
   public void testFindOne() {
       Comment comment = mongoTemplate.findById("11111", Comment.class);
       System.out.println(comment);
   }

   //条件查询
   @Test
   public void testQuery() {
//        Query query = Query.query(Criteria.where("_id").is("1111111"));
       Query query = Query.query(Criteria.where("likes").lt(28));
       query.with(Sort.by(Sort.Direction.DESC,"likes"));
       Pageable pageable = PageRequest.of(1,3);
       query.with(pageable);
       List<Comment> comments = mongoTemplate.find(query, Comment.class);
       System.out.println(comments);
   }

   //删除
   @Test
   public void testDelete(){
       mongoTemplate.remove(Query.query(Criteria.where("_id").is("1111111")),Comment.class);
   }

   //修改
   @Test
   public void testUpdate(){
       Query query = Query.query(Criteria.where("_id").is("11111"));
       Update update = new Update().set("content","aaaaa");
       mongoTemplate.updateMulti(query,update,Comment.class);
   }

}
### Spring Boot 整合 MongoDB 示例教程 #### 1. 添加依赖项 为了使 Spring Boot 应用程序能够与 MongoDB 进行交互,需在 `pom.xml` 文件中引入必要的依赖: ```xml <dependency> <groupId>org.springframework.boot</groupId> <artifactId>spring-boot-starter-data-mongodb</artifactId> </dependency> ``` 此操作确保应用程序具备访问 MongoDB 所需的功能。 #### 2. 配置 application.yml 文件 对于未设置密码保护的 MongoDB 实例,在 `application.yml` 中可采用如下方式指定连接参数[^3]: ```yaml spring: data: mongodb: uri: mongodb://localhost:27017/testdb ``` 而对于设置了用户名和密码认证的情况,则应按照以下格式编写配置信息[^2]: ```yaml spring: data: mongodb: uri: mongodb://username:password@localhost:27017/mydatabase database: mydatabase ``` 以上两种方法均能有效建立至目标数据库实例的链接。 #### 3. 创建实体类 (Model Class) 定义用于映射文档结构的数据模型。例如创建名为 `User.java` 的 POJO 类来表示用户记录: ```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 int age; // Getters and Setters... } ``` 此类通过注解指定了集合名称以及字段属性,便于后续 CRUD 操作。 #### 4. 编写 Repository 接口 利用 Spring Data 提供的支持简化数据存取逻辑。针对上述 `User` 对象构建相应的仓库接口: ```java import org.springframework.data.mongodb.repository.MongoRepository; public interface UserRepository extends MongoRepository<User, String> {} ``` 借助泛型机制自动实现了基本增删改查功能,无需额外编码实现具体业务处理流程。 #### 5. 使用 Service 层封装业务逻辑 最后一步是在服务层调用仓储组件完成实际的任务需求。比如查询所有用户的列表: ```java @Service public class UserService { @Autowired private UserRepository userRepository; public List<User> getAllUsers() { return new ArrayList<>(userRepository.findAll()); } } ``` 至此已经完成了整个集成过程的关键环节介绍。
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值