Můžete použít $addToSet
pro přidání položky do pole a $set
aktualizovat existující položku v tomto poli.
Následující přidá novou položku do pole, pokud userID
nebyl nalezen v poli :
db.doc.update({
visits: {
"$not": {
"$elemMatch": {
"userID": 4
}
}
}
}, {
$addToSet: {
visits: {
"userID": 4,
"time": 1482607614
}
}
}, { multi: true });
Následující text aktualizuje položku pole vnořených dokumentů, pokud odpovídá userId
:
db.doc.update({ "visits.userID": 2 }, {
$set: {
"visits.$.time": 1482607614
}
}, { multi: true });