Spring Mongo仅通过新POJO

用户模型:

@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条件。在这种情况下最好的解决方案是什么?

iCMS 回答:Spring Mongo仅通过新POJO

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

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中设置地图,然后在数据库中更新。

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();
本文链接:https://www.f2er.com/2188459.html

大家都在问