Du kan använda $addToSet
för att lägga till ett objekt i arrayen och $set
för att uppdatera ett befintligt objekt i denna array.
Följande kommer att lägga till ett nytt objekt till arrayen om userID
finns inte i arrayen :
db.doc.update({
visits: {
"$not": {
"$elemMatch": {
"userID": 4
}
}
}
}, {
$addToSet: {
visits: {
"userID": 4,
"time": 1482607614
}
}
}, { multi: true });
Följande kommer att uppdatera underdokumentmatrisobjektet om det matchar userId
:
db.doc.update({ "visits.userID": 2 }, {
$set: {
"visits.$.time": 1482607614
}
}, { multi: true });