Пользовательский метод для обновления запроса с данными весны MongoRepository - PullRequest
0 голосов
/ 25 апреля 2018

Я использую org.springframework.data.mongodb.repository.MongoRepository.Я написал некоторый пользовательский метод, как показано ниже:

public interface DocRepository extends MongoRepository<Doc, String> {
     Doc findByDocIdAndAssignmentId(final String docId, final String assignemtId);
}

Как я могу написать пользовательский метод, который обновляет все записи при соответствии критериям.

Например, установить поле наклона документа на «abc», если идентификатор присваивания «xyz»?

Ответы [ 3 ]

0 голосов
/ 29 апреля 2018

Я нашел com.mongodb.MongoClient для достижения вышеуказанного

0 голосов
/ 14 июля 2018

1) Вам необходимо создать интерфейс, например, CustomDocRepository, и добавить эти интерфейсы в качестве базы для вашего DocRepository:

public interface DocRepository extends MongoRepository<Doc, String>, CustomDocRepository {

    void updateDocumentTitle(String id, String title);

}

2) Вам необходимо добавить реализацию для CustomDocRepository:

@Repository
public class CustomDocRepositoryImpl implements CustomDocRepository {
  @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();
}
}

Это все, что вам нужно сделать

0 голосов
/ 25 апреля 2018

При условии, что у вас есть autowired атрибут mongoTemplate в вашем service классе.Добавьте приведенный ниже код для обновления документа.

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.

Добро пожаловать на сайт PullRequest, где вы можете задавать вопросы и получать ответы от других членов сообщества.
...