mongodb - Spring Mongo 仅通过新 POJO 的非空字段进行更新

标签 mongodb spring-boot spring-data-mongodb spring-mongo mongorepository

用户模型:

@Document(collection = "USER")
public class UserModel {
    private String id;
    private String username;
    @Indexed(unique = true)
    private String email;
    private String password;
    private String firstName;
    private String lastName;
}

用户资料库:

@Repository
public interface UserRepository extends MongoRepository<UserModel, String> {

    Optional<UserModel> findByEmail(String email);
    Optional<UserModel> findByUsername(String username);
}

像这样保存用户文档:

@Autowired
UserRepository userRepo;

public someMethod() {
    UserModel user = new UserModel();
    //Set all fields....
    userRepo.save(user);
}

尝试像这样更新:

@Autowired
UserRepository userRepo;

public someMethod() {
    UserModel user = new UserModel();
    user.setId("A valid Id got from database by last insert")
    user.setFirstName("New first name");
    // Remaining fields are null now
    userRepo.save(user);
}

此处空值将由 MongoRepository 插入。

有什么设置可以告诉 MongoRepository 在更新时避免空值?

如果我们通过 MongoTemplate updateFirst() 方法执行此操作,我们必须为 POJO 的所有字段添加 if 条件。在这种情况下,最佳解决方案是什么?

最佳答案

尝试首先从数据库中获取用户然后更新您的数据并保存在数据库中。

UserModel user = userRepo.findById(id); // Fetch from database
user.setFirstName("New first name");    // Update the data
userRepo.save(user);                    // Save in the database

或者使用自定义查询来仅更新选定的字段。在这里让它动态,创建一个Map<String, Object>来自 UserModel并删除空值。

ObjectMapper oMapper = new ObjectMapper();
Map<String, Object> dataMap = oMapper.convertValue(user, Map.class);
map.values().removeIf(Objects::isNull);

现在在 Update 中设置 map 然后在数据库中更新。

Update update = new Update();
dataMap.forEach(update::set);
Query query = new Query().addCriteria(where("_id").is(id));
mongoTemplate.update(UserModel.class).matching(query).apply(update).first();

关于mongodb - Spring Mongo 仅通过新 POJO 的非空字段进行更新,我们在Stack Overflow上找到一个类似的问题: https://stackoverflow.com/questions/62237070/

相关文章:

java - 如何访问注释中的属性值?

MongoDB:在数字或字符串数​​组上使用 $elemMatch

mongodb - 我应该使用 "_id"中的时间戳吗?

mongodb - 将ElasticSearch与MongoDB数据库集成

java - Spring Security 教程不适用于 Tomcat 服务器

java - 从命令行覆盖 spring 配置服务器配置

java - 如何从 wsdl 生成请求和响应类?

spring-data - 是否可以在 Spring Data 中使用 Mongo $natural 运算符?

MongoDB按数组内部元素分组

java - 如何将 MongoDB 结果从 $dateToString 操作转换为 Java 对象