用户模型:
@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/