是否可以使用一次更新来更新文档的两个子数组(无需检索文档,并使用开放式并发对其进行更新)?
假设我有以下文档:
{ "_id" : 2,
"arr1" : [
{ "Id" : 10, "Value" : "abc" },
{ "Id" : 20, "Value" : "abc" },
{ "Id" : 30, "Value" : "abc" },
{ "Id" : 40, "Value" : "abc" },
{ "Id" : 50, "Value" : "abc" }
],
"arr2" : [
{ "Id" : 12, "Text" : "abc" },
{ "Id" : 22, "Text" : "abc" },
{ "Id" : 32, "Text" : "abc" },
{ "Id" : 42, "Text" : "abc" },
{ "Id" : 52, "Text" : "abc" }
]
}我试着这样做,但它似乎没有修改正确的子文档:
db.col.update(
{ "_id": 2, arr1: { $elemMatch: { Id: 30 } }, arr2: { $elemMatch: {Id: 42} } },
{ $set: {
"arr1.$.Value": "Changed First",
"arr2.$.Text": "Changed Second"
}
})发布于 2013-02-14 22:08:09
在我看来,如果您的数据看起来像这样,您将能够轻松地执行更新:
{
"_id" : 2,
"arr1" : {
"10": "abc",
"20": "abc",
"30": "abc",
"40": "abc",
"50": "abc"
}
}https://stackoverflow.com/questions/14876116
复制相似问题