如何确保在创建时可以插入特定字段,但可以选择在更新对象时将其排除。 我基本上是在寻找以下内容:
mongoOperations.save(theObject, <fields to ignore>)
据我所知,最近推出的 @ReadOnlyProperty 将忽略该属性的插入和更新。
通过实现我的Custom MongoTemplate并覆盖其 doUpdate 方法,我能够获得所需的行为,如下所示:
@Override
protected WriteResult doUpdate(String collectionName, Query query,
Update originalUpdate, Class<?> entityClass, boolean upsert, boolean multi) {
Update updateViaSet = new Update();
DBObject dbObject = originalUpdate.getUpdateObject();
Update filteredUpdate = Update.fromDBObject(dbObject, "<fields to ignore>");
for(String key : filteredUpdate.getUpdateObject().keySet()){
Object val = filteredUpdate.getUpdateObject().get(key);
System.out.println(key + "::" + val);
updateViaSet.set(key, filteredUpdate.getUpdateObject().get(key));
}
return super
.doUpdate(collectionName, query, updateViaSet, entityClass, upsert, multi);
}
但问题是现在它将对所有内容使用Mongo $set形式的更新,而不仅仅是针对特定情况。 请告知是否有更简单(和正确)的方法来实现这一目标。
答案 0 :(得分:0)
在创建更新对象时,请使用$ setOnInsert而不是$ set。它在春季mongo中也可用。
如果使用upsert:true进行更新操作会导致插入文档,则$ setOnInsert会将指定的值分配给文档中的字段。如果更新操作未导致插入,则$ setOnInsert不执行任何操作。