Използвайте метода на обвивката findAndModify
за да отговарят на вашите нужди.
Но не можете да използвате позиционния знак $код>
повече от веднъж, докато проектирате в MongoDb, така че може да се наложи да го следите сами от страна на клиента.
Използвайте arrayFilters
за актуализиране на дълбоко вложен поддокумент, вместо позиционен оператор за всички $[]
.
По-долу има работеща заявка -
var query = {
universe: 'comics'
};
var update = {
$set: {
'saga.$[outer].characters.$[inner].character': 'lobezno',
'saga.$[outer].characters.$[inner].picture': '618035022354.png',
}
};
var fields = {
'saga.characters': 1
};
var updateFilter = {
arrayFilters: [
{
'outer.name': 'x-men'
},
{
'inner.character': 'wolverine'
}
]
};
db.collection.findAndModify({
query,
update,
fields,
arrayFilters: updateFilter.arrayFilters
new: true
});