sql >> Database teknologi >  >> NoSQL >> MongoDB

MongoDB Java Driver Update Sub-Document

Hvis dette er opdateringen indstillet i mongodb:

 {$set: 
        { "numberOfDownloads" : "453", 
          "documents" : 
                { "downloads" : "453"}
        }
 }

Du kan bruge klassen Document på denne måde:

Document upDocValue = new Document("numberOfDownloads": "453")
                      .append("documents.downloads":"453");

Dette vil give dig:

{
  "numberOfDownloads": "453",
  "documents" : 
    { "downloads" : "453"}
}

Så kan du oprette det ydre dokument med:

Document upDocSet = new Document("$set",updDocValue);

Dette skulle give dig:

{$set: 
      { "numberOfDownloads" : "453", 
            "documents" : 
                  { "downloads" : "453"}
      }
}

Så kører du din forespørgsel her:

collection.updateOne(upDocQuery,upDocSet);

Så du har til sidst:

Document updDocQuery = new Document("_id", "9999996978c9df5b02999999");

Document upDocValue = new Document("numberOfDownloads": "453")
                          .append("documents.downloads":"453");

Document upDocSet = new Document("$set",updDocValue);

collection.updateOne(upDocQuery,upDocSet);



  1. mongo .find returnerer specifikt felt kun for alle brugere

  2. Sæt grænser for mongo db-samling

  3. Hvordan sammenligner man to strenge i mongoDB fjederdata?

  4. mongodb starter ikke på ubuntu 18.04