使用 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

使用spring-data-solr做solr客户端

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