使用 Spring Data MongoRepository 进行更新查询的自定义方法
Posted
技术标签:
【中文标题】使用 Spring Data MongoRepository 进行更新查询的自定义方法【英文标题】:Custom method for update query with spring data MongoRepository 【发布时间】:2018-10-05 19:10:42 【问题描述】:我正在使用 org.springframework.data.mongodb.repository.MongoRepository。我写了一些自定义方法,如下所示,
public interface DocRepository extends MongoRepository<Doc, String>
Doc findByDocIdAndAssignmentId(final String docId, final String assignemtId);
如何编写一个自定义方法,在满足条件时更新所有条目。
例如,如果分配 id 为“xyz”,则将文档倾斜字段设置为“abc”?
【问题讨论】:
【参考方案1】:1) 您需要创建接口,例如 CustomDocRepository 并将此接口添加为您的 DocRepository 的基础:
public interface DocRepository extends MongoRepository<Doc, String>, CustomDocRepository
void updateDocumentTitle(String id, String title);
2) 您需要为 DocRepository 添加实现:
@Repository
public class CustomDocRepositoryImpl implements DocRepository
@Autowired
private MongoTemplate mongoTemplate;
@Override
public void updateDocumentTitle(String id, String title)
Query query = new Query().addCriteria(where("_id").is(id));
Update update = new Update();
update.set("title", title);
mongoTemplate.update(Doc.class).matching(query).apply(update).first();
这就是你需要做的一切
【讨论】:
docs.spring.io/spring-data/mongodb/docs/current/reference/html/… 9.6。 Spring Data Repositories 的自定义实现【参考方案2】:如果您的service
类中有autowired
属性mongoTemplate
。添加以下代码以更新文档。
Query query = new Query();
query.addCriteria(Criteria.where("assignmentId").is("xyz"))
Update update = new Update();
update.set("title", "abc");
mongoTemplate.updateFirst(query, update, Doc.class);
您不需要findByDocIdAndAssignmentId
来进行更新。
【讨论】:
其实我没有mongoTemplate。我正在寻找不使用 mongoTemplate 的自定义更新操作方法 你得到答案了吗?【参考方案3】:我找到了com.mongodb.MongoClient来实现上面的
【讨论】:
以上是关于使用 Spring Data MongoRepository 进行更新查询的自定义方法的主要内容,如果未能解决你的问题,请参考以下文章
Spring Boot(17)——使用Spring Data JPA
springboot :spring data jpa的使用
将 Spring 安全 ACL 与 spring-data-mongodb 一起使用
Spring Boot 使用 spring.datasource.data 的时候找不到数据文件
006-spring-data-elasticsearch 3.0.0.0使用-spring-data之Elasticsearch Repositories