第一步:在pom.xml文件中引入下述依赖,当前Spring Boot的版本为 2.7.6:
<dependency>
<groupId>org.springframework.boot</groupId>
<artifactId>spring-boot-starter-data-mongodb</artifactId>
<version>2.7.6</version>
</dependency>
第二步:创建数据库users,并且user集合中插入一条数据
use users;
db.user.insert({name:"张三",age:18,address:"广东"})
第三步:在application.yml文件配置连接MongoDB
spring:
data:
mongodb:
uri: mongodb://127.0.0.1:27017/users
第四步:构建user集合的实体类(需要注意的是这个实体类中我没有添加@Document、@Id、@Field、@Transient等注解)
package com.example.demo.mongo;
import lombok.Data;
@Data
public class User {
private String name;
private int age;
private String address;
}
虽然没写这些注解,但只要字段定义名称一致,则不会 影响下述测试案例的运行。如果是其它相关的使用,还是建议加上去,避免不必要的麻烦。
第五步:构建测试类,测试更新整个文档对象
package com.example.demo;
import com.example.demo.mongo.User;
import org.bson.Document;
import org.junit.jupiter.api.Test;
import org.springframework.beans.factory.annotation.Autowired;
import org.springframework.boot.test.context.SpringBootTest;
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 java.util.List;
@SpringBootTest
public class UserApplicationTests {
@Autowired
private MongoTemplate mongoTemplate;
@Test
void contextLoads() {
User user = new User();
user.setName("李四");
user.setAge(20);
user.setAddress("上海");
Query query = new Query(Criteria.where("_id").is("646ed68ab9002f0de86da306"));
Document doc = new Document();
mongoTemplate.getConverter().write(user, doc);
Update update = Update.fromDocument(doc);
mongoTemplate.upsert(query, update, "user");
List<User> users = mongoTemplate.findAll(User.class);
System.out.println(users);
}
}
执行上述代码,其输出结果为:
[User(name=李四, age=20, address=上海)]
进入到Mongo的客户端中可以看到文档对象里面的数据已更新,如下图所示:
以前的话如果我们想更新一个文档对象时,需要通过Update对象(org.springframework.data.mongodb.core.query.Update)一个一个的赋予key、value值,当更新的字段值比较多时,操作步骤还是比较繁琐的。
当前这种用法就可以避免上述这种情况,直接通过实体类去覆盖更新就可以。
另外如果不想过于粗暴,还可以指定字段进行排除,进行覆盖更新时不更新该字段的值:
Update.fromDocument(org.bson.Document object, String... exclude)