sql >> Databáze >  >> NoSQL >> MongoDB

aktualizovat konkrétní prvek z pole vnořených dokumentů mongodb, kde má dvě shody

Demo – https://mongoplayground.net/p/VaE28ujeOPx

Použijte $ (aktualizace)

db.collection.update({
  "notes": {
    "$elemMatch": { "block": 2, "curse": 5 }
  }
},
{
  $set: { "notes.$.score.b4": 40 }
})

Přečtěte si upsert :pravda

Aktualizovat

Demo – https://mongoplayground.net/p/iQQDyjG2a_B

Použijte $function

db.collection.update(
    { "_id": "sad445" },
    [
      {
        $set: {
          notes: {
            $function: {
              body: function(notes) {
                        var record = { curse:5, block:2, score:{ b4:40 } };
                        if(!notes || !notes.length) { return [record]; } // create new record and return in case of no notes
                        var updated = false;
                        for (var i=0; i < notes.length; i++) {
                            if (notes[i].block == 2 && notes[i].curse == 5) { // check condition for update
                                updated = true;
                                notes[i].score.b4=40; break; // update here
                            }
                        }
                        if (!updated) notes.push(record); // if no update push the record in notes array
                        return notes;
                    },
              args: [
                "$notes"
              ],
              lang: "js"
            }
          }
        }
      }
    ]
)


  1. Ukládání a dotazování JSON z databáze

  2. Najděte dokument s ObjectID v mongoDB

  3. NEBO dotaz odpovídající nule nebo s Mongoidem stále odpovídá ?

  4. MongoError:Toto nasazení MongoDB nepodporuje opakovatelné zápisy. Přidejte do připojovacího řetězce retryWrites=false