这是用 Morphia 更新 mongodb 对象的最佳实践吗
Is this best practice for updating mongodb object with Morphia
我在我的 SparkJava 项目中使用 MongoDB 和 Morphia。这对我来说是一次新的冒险。我想知道这是否是更新数据库中现有对象的最佳方式?如果我想替换更新整个文档,有没有更好的方法?
我的 ContentBlockDao 中的示例更新方法
@Override
public ContentBlock update(ContentBlock contentBlock) throws DaoException {
Query<ContentBlock> query = datastore.createQuery(ContentBlock.class)
.field("id").equal(new ObjectId(contentBlock.getId()));
UpdateOperations<ContentBlock> updateOperations = setValuesForUpdate(
datastore.createUpdateOperations(ContentBlock.class),
contentBlock);
datastore.update(query, updateOperations);
return query.get();
}
private UpdateOperations setValuesForUpdate(UpdateOperations<ContentBlock> updateOperations,
ContentBlock contentBlock) {
updateOperations.set("html", contentBlock.getHtml());
updateOperations.set("lastUpdater", contentBlock.getLastUpdater());
return updateOperations;
}
让吗啡为您管理对象更新。
使用保存方法完成文档替换。如果实体中不存在 _id
,则创建一个新文档,否则替换文档。
<T> Key<T> save(T entity);
使用合并方法进行选择性字段更新。这会将 dbobject 与输入实体进行比较并更新更改的字段。
<T> Key<T> merge(T entity)
对于任何其他查询条件,您可以使用更新方法。
<T> UpdateResults update(T entity, UpdateOperations<T> var2);
我在我的 SparkJava 项目中使用 MongoDB 和 Morphia。这对我来说是一次新的冒险。我想知道这是否是更新数据库中现有对象的最佳方式?如果我想替换更新整个文档,有没有更好的方法?
我的 ContentBlockDao 中的示例更新方法
@Override
public ContentBlock update(ContentBlock contentBlock) throws DaoException {
Query<ContentBlock> query = datastore.createQuery(ContentBlock.class)
.field("id").equal(new ObjectId(contentBlock.getId()));
UpdateOperations<ContentBlock> updateOperations = setValuesForUpdate(
datastore.createUpdateOperations(ContentBlock.class),
contentBlock);
datastore.update(query, updateOperations);
return query.get();
}
private UpdateOperations setValuesForUpdate(UpdateOperations<ContentBlock> updateOperations,
ContentBlock contentBlock) {
updateOperations.set("html", contentBlock.getHtml());
updateOperations.set("lastUpdater", contentBlock.getLastUpdater());
return updateOperations;
}
让吗啡为您管理对象更新。
使用保存方法完成文档替换。如果实体中不存在 _id
,则创建一个新文档,否则替换文档。
<T> Key<T> save(T entity);
使用合并方法进行选择性字段更新。这会将 dbobject 与输入实体进行比较并更新更改的字段。
<T> Key<T> merge(T entity)
对于任何其他查询条件,您可以使用更新方法。
<T> UpdateResults update(T entity, UpdateOperations<T> var2);