MongoDB
 sql >> база данни >  >> NoSQL >> MongoDB

актуализира конкретен елемент от вложен масив от документи mongodb, където има две съвпадения

Демо - https://mongoplayground.net/p/VaE28ujeOPx

Използвайте $ (актуализация)

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

Прочетете upsert :вярно

Актуализация

Демо - https://mongoplayground.net/p/iQQDyjG2a_B

Използвайте $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. Може ли geoNear в MongoDB да върне подмножество от полета в документ?

  2. MongoDB - Максимален размер на файла с помощта на GridFS

  3. Включете специфични полета в индекс за заместващи символи в MongoDB

  4. как да намеря отделно поле на модел при условие и в mongoose?

  5. Как да промените структурата на резултатите за намаляване на картата на MongoDB?