Das Problem in Ihrem Code ist dot-notation
weil Wenn Sie die Punktnotation angeben, gehen Sie davon aus, dass die angegebenen Filterkriterien mit dem einzelnen Array-Element übereinstimmen müssen, das alle Kriterien erfüllt. Aber das tut es nicht. Die Punktnotation auf Arrays kann jedes Array-Element aufnehmen, wenn ein einzelnes Kriterium zutrifft. Deshalb erhalten Sie das unerwartete Update.
Sie müssen $elemMatch
verwenden
um alle Filter im array
abzugleichen Element.
db.coll.update({
'_id' : 28,
n: {
$elemMatch:{
a : new ObjectId('4ef85a3e46b3b84408000000'),
c : 28 }
}
},
{
$push : {
'n.$.p' : ObjectId("4b97e62bf1d8c7152c9ccb74")
},
$set : {
'n.$.t' : ISODate("2013-05-13T14:22:46.777Z")
}
})
und die Ausgabe ist
{
"a" : ObjectId("4ef85a3e46b3b84408000000"),
"c" : 28,
"p" : [
ObjectId("4f00631046b3b85002000000"),
ObjectId("4b97e62bf1d8c7152c9ccb74")
],
"t" : ISODate("2013-05-13T14:22:46.777Z"),
"u" : 26
}