För att göra detta atomärt måste alla dina tre exempeldokument vara en del av samma dokument. MongoDB utför endast operationer atomärt på enkla dokument:https://www.mongodb.org/ display/DOCS/Atomic+Operations
Om de är en del av ett enda dokument skulle följande ändra ordningen på det andra och tredje underdokumentet:
> db.so.find().pretty();
{
"_id" : ObjectId("4f55e7ba362e2f2a734c92f8"),
"subs" : [
{
"author_id" : "a",
"class" : "principle",
"content_id" : null,
"host_id" : null,
"modified_date" : 1330935540,
"order" : 1,
"pub_date" : 1330935540,
"score" : 0,
"text" : "Hello World!",
"vote_down_count" : 0,
"vote_up_count" : 0
},
{
"author_id" : "a",
"class" : "principle",
"content_id" : null,
"host_id" : null,
"modified_date" : 1330935538,
"order" : 2,
"pub_date" : 1330935538,
"score" : 0,
"text" : "Nice to meet you.",
"vote_down_count" : 0,
"vote_up_count" : 0
},
{
"author_id" : "a",
"class" : "principle",
"content_id" : null,
"host_id" : null,
"modified_date" : 1330935548,
"order" : 3,
"pub_date" : 1330935548,
"score" : 0,
"text" : "Great!",
"vote_down_count" : 0,
"vote_up_count" : 0
}
]
}
Fråga:
db.so.update(
{ _id: new ObjectId("4f55e7ba362e2f2a734c92f8")},
{ $set : { 'subs.1.order' : 3, 'subs.2.order' : 2 } }
);
Resultat:
> db.so.find().pretty();
{
"_id" : ObjectId("4f55e7ba362e2f2a734c92f8"),
"subs" : [
{
"author_id" : "a",
"class" : "principle",
"content_id" : null,
"host_id" : null,
"modified_date" : 1330935540,
"order" : 1,
"pub_date" : 1330935540,
"score" : 0,
"text" : "Hello World!",
"vote_down_count" : 0,
"vote_up_count" : 0
},
{
"author_id" : "a",
"class" : "principle",
"content_id" : null,
"host_id" : null,
"modified_date" : 1330935538,
"order" : 3,
"pub_date" : 1330935538,
"score" : 0,
"text" : "Nice to meet you.",
"vote_down_count" : 0,
"vote_up_count" : 0
},
{
"author_id" : "a",
"class" : "principle",
"content_id" : null,
"host_id" : null,
"modified_date" : 1330935548,
"order" : 2,
"pub_date" : 1330935548,
"score" : 0,
"text" : "Great!",
"vote_down_count" : 0,
"vote_up_count" : 0
}
]
}