簡體   English   中英

如何通過 Mongock 向集合中的所有文檔添加新字段?

[英]How to add new field to all documents in a collection trough Mongock?

我有一個文檔集合,如下所示:

[
    {
        "firstName" : "Foo",
        "phone" : "+1 111 1111",
        "car": "Toyota"
    },
    {
        "firstName" : "Bar",
        "phone" : "+2 222 2222",
        "car": "Honda"
    }
]

我想為這個集合“Persons”中的每個文檔添加一個新字段,我可以在控制台上執行語法,但是由於我需要以某種方式存儲更改,所以我們使用的是 Mongock。 而且我找不到通過MongockTemplate執行update的方法。 文件的{ "key": "value" }是 static,我什至不需要變量來傳遞它們,最終文件應該如下所示:

[
    {
        "firstName" : "Foo",
        "phone" : "+1 111 1111",
        "car": "Toyota",
        "species" : "human"
    },
    {
        "firstName" : "Bar",
        "phone" : "+2 222 2222",
        "car": "Honda",
        "species" : "human"
    }
]

我不知道如何在MongockTemplate中執行如下查詢:

db.getCollection('Persons').update(
  {},
  { $set: {"species": "human"} },
  false,
  true
)

Here's the StackTrace:

```java
22:18:48.237 [main] ERROR io.changock.runner.core.ChangockBase - Error in changock process. ABORTED MIGRATION
io.changock.migration.api.exception.ChangockException: Error in method[UpdateAddTypeField.updateAddTypeField] : 'com.mongodb.client.result.UpdateResult org.springframework.data.mongodb.core.MongoTemplate.updateMulti(org.springframework.data.mongodb.core.query.Query, org.springframework.data.mongodb.core.query.Update, java.lang.String)'
    at io.changock.runner.core.MigrationExecutor.processExceptionOnChangeSetExecution(MigrationExecutor.java:195)
    at io.changock.runner.core.MigrationExecutor.processSingleChangeSet(MigrationExecutor.java:102)
    at io.changock.runner.core.MigrationExecutor.lambda$processSingleChangeLog$2(MigrationExecutor.java:94)
    at io.changock.runner.core.MigrationExecutor.executeInTransactionIfStrategyOrUsualIfNot(MigrationExecutor.java:80)
    at io.changock.runner.core.MigrationExecutor.processSingleChangeLog(MigrationExecutor.java:94)
    at io.changock.runner.core.MigrationExecutor.lambda$processAllChangeLogs$1(MigrationExecutor.java:88)
    at io.changock.runner.core.MigrationExecutor.executeInTransactionIfStrategyOrUsualIfNot(MigrationExecutor.java:80)
    at io.changock.runner.core.MigrationExecutor.processAllChangeLogs(MigrationExecutor.java:88)
    at io.changock.runner.core.MigrationExecutor.lambda$executeMigration$0(MigrationExecutor.java:69)
    at io.changock.runner.core.MigrationExecutor.executeInTransactionIfStrategyOrUsualIfNot(MigrationExecutor.java:80)
    at io.changock.runner.core.MigrationExecutor.executeMigration(MigrationExecutor.java:69)
    at io.changock.runner.spring.v5.core.SpringMigrationExecutor.executeMigration(SpringMigrationExecutor.java:38)
    at io.changock.runner.core.ChangockBase.execute(ChangockBase.java:44)
    at io.changock.runner.spring.v5.ChangockSpringBuilderBase$ChangockSpringApplicationRunner.run(ChangockSpringBuilderBase.java:110)
    at org.springframework.boot.SpringApplication.callRunner(SpringApplication.java:786)
    at org.springframework.boot.SpringApplication.callRunners(SpringApplication.java:776)
    at org.springframework.boot.SpringApplication.run(SpringApplication.java:322)
    at com.hiden.subhiden.project.subhidenprojecterviceApplication.main(subhidenprojecterviceApplication.java:22)
Caused by: java.lang.reflect.InvocationTargetException: null
    at java.base/jdk.internal.reflect.NativeMethodAccessorImpl.invoke0(Native Method)
    at java.base/jdk.internal.reflect.NativeMethodAccessorImpl.invoke(NativeMethodAccessorImpl.java:62)
    at java.base/jdk.internal.reflect.DelegatingMethodAccessorImpl.invoke(DelegatingMethodAccessorImpl.java:43)
    at java.base/java.lang.reflect.Method.invoke(Method.java:566)
    at io.changock.runner.core.MigrationExecutor.executeChangeSetMethod(MigrationExecutor.java:174)
    at io.changock.runner.core.MigrationExecutor.executeAndLogChangeSet(MigrationExecutor.java:127)
    at io.changock.runner.spring.v5.core.SpringMigrationExecutor.executeAndLogChangeSet(SpringMigrationExecutor.java:44)
    at io.changock.runner.core.MigrationExecutor.processSingleChangeSet(MigrationExecutor.java:100)
    ... 16 common frames omitted
Caused by: java.lang.NoSuchMethodError: 'com.mongodb.client.result.UpdateResult org.springframework.data.mongodb.core.MongoTemplate.updateMulti(org.springframework.data.mongodb.core.query.Query, org.springframework.data.mongodb.core.query.Update, java.lang.String)'
    at com.github.cloudyrock.mongock.driver.mongodb.springdata.v2.decorator.impl.MongockTemplate.lambda$updateMulti$53(MongockTemplate.java:383)
    at io.changock.driver.api.lock.guard.invoker.LockGuardInvokerImpl.invoke(LockGuardInvokerImpl.java:18)
    at com.github.cloudyrock.mongock.driver.mongodb.springdata.v2.decorator.impl.MongockTemplate.updateMulti(MongockTemplate.java:383)
    at com.hiden.subhiden.project.dbchangelogs.UpdateAddTypeField.updateAddTypeField(UpdateAddTypeField.java:32)
    ... 24 common frames omitted
22:18:48.315 [main] ERROR o.s.b.d.LoggingFailureAnalysisReporter - 

***************************
APPLICATION FAILED TO START
***************************

Description:

An attempt was made to call a method that does not exist. The attempt was made from the following location:

    com.github.cloudyrock.mongock.driver.mongodb.springdata.v2.decorator.impl.MongockTemplate.lambda$updateMulti$53(MongockTemplate.java:383)

The following method did not exist:

    'com.mongodb.client.result.UpdateResult org.springframework.data.mongodb.core.MongoTemplate.updateMulti(org.springframework.data.mongodb.core.query.Query, org.springframework.data.mongodb.core.query.Update, java.lang.String)'

The method's class, org.springframework.data.mongodb.core.MongoTemplate, is available from the following locations:

    jar:file:/home/johnnes/.m2/repository/org/springframework/data/spring-data-mongodb/3.0.5.RELEASE/spring-data-mongodb-3.0.5.RELEASE.jar!/org/springframework/data/mongodb/core/MongoTemplate.class

The class hierarchy was loaded from the following locations:

    org.springframework.data.mongodb.core.MongoTemplate: file:/home/johnnes/.m2/repository/org/springframework/data/spring-data-mongodb/3.0.5.RELEASE/spring-data-mongodb-3.0.5.RELEASE.jar


Action:

Correct the classpath of your application so that it contains a single, compatible version of org.springframework.data.mongodb.core.MongoTemplate


Process finished with exit code 1

任何你可以用普通的 MongoTemplate 做的事情,你也可以用 MongockTemplate 做。

在這種情況下,您可以調整 UpdateOptions 和其他一些東西,但它可以像

       Document updater = new Document()
          .append("$set", new Document().append("species", "human"));
        
       mongockTemplate.getCollection("Persons")
           .updateMany(new Document(), updater);

雖然之前的答案仍然有效,但在您發布錯誤日志后,我想我發現了問題。 您正在使用不兼容版本的 MongoDB Spring 數據和 Mongock 驅動程序。 一方面,您使用Z206E3718AF092F80CAE771CCACASZZZZ 3.0.5.RELEASE以及另一端, mongodb-spring-data-v3正在使用Mongock dripy88 todymymodb mongodb-spring-data-v2 Zpring-deby deby e eyy pe y is istaa-def2 toda toddatadatdatadatdatdatdatdat, mongodb-spring-data-v3代替

更多信息,請查看官方文檔

因此,經過多次嘗試后,我找到了以下解決方案:通過 MongockTemplate 獲取 MongoTemplate Impl 的實例並使用它而不是 MongockTemplate。 我仍然不知道它為什么起作用。 如果我弄清楚了,我會更新這個線程。

@ChangeSet(order = "1", id = "updateData", author = "J. Souza")
  public void updateCollectionAddSpecieField(MongockTemplate mongockTemplate) {

    MongoTemplate template = mongockTemplate.getImpl();

    Query query = new Query();
    query.addCriteria(where(SPECIES_FIELD).exists(false));
    Update update = new Update();
    update.set(SPECIES, HUMAN);
    UpdateResult updateResult = template
        .updateMulti(query, update, "Collection-Name");

    log.info("Matched {} | Modified {}",
        updateResult.getMatchedCount(), updateResult.getModifiedCount());
  }

暫無
暫無

聲明:本站的技術帖子網頁,遵循CC BY-SA 4.0協議,如果您需要轉載,請注明本站網址或者原文地址。任何問題請咨詢:yoyou2525@163.com.

 
粵ICP備18138465號  © 2020-2024 STACKOOM.COM