MongoDB
 sql >> Baza danych >  >> NoSQL >> MongoDB

zaktualizuj określony element z zagnieżdżonej tablicy dokumentów mongodb, gdzie ma dwa dopasowania

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

Użyj $ (aktualizacja)

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

Przeczytaj upsert :prawda

Aktualizacja

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

Użyj $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. Redis
  2.   
  3. MongoDB
  4.   
  5. Memcached
  6.   
  7. HBase
  8.   
  9. CouchDB
  1. Zagnieżdżone obiekty MongoDB Norm

  2. Przechowywanie DateTime w MongoDB wpływa na wydajność

  3. Ostrzeżenie:uzyskiwanie dostępu do nieistniejącej właściwości „MongoError” eksportu modułu wewnątrz zależności cyklicznej

  4. Mongo-PHP — wyjątek MongoCursor ze sterownikiem MongoDB PHP w wersji 1.6

  5. Wdrażanie baz danych w chmurze za pomocą ClusterControl 1.6