我很难理解如何在mongoDB的数组对象内更新标签数组。
我有一个对象数组及其相应的ObjectID,我想在mongoDB上更新标签。我尝试的是使用一个循环,使用updateOne指定ObjectID作为查询来查找相应的文档。
像这样:
nodes.forEach(node => {
const query = { '_id' : ObjectId(node.Id) }
db.collection(collection).updateOne(
query,
{ $set: { 'tags': value } },
function(err, result) {
if (err) {
throw err;
}
console.log(result);
});
});
不幸的是,这不起作用。我已经尝试了其他方法,但我找不到任何工作
我有以下mongodb数据结构:{
"_id": {
"$oid": "6022bc9f9b55276bd39f4e0"
},
"name": "TestProject",
"projectData": {
"nodes": [
{
"data": {
"_id": {
"$oid": "6022bc959b559276bd39f4be"
},
"nodeData": {
"tags": []
}
}
},
{
"data": {
"_id": {
"$oid": "7022bc959b559276bd39f4ce"
},
"nodeData": {
"tags": []
}
}
},
{
"data": {
"_id": {
"$oid": "8022bc959b559276bd39f4de"
},
"nodeData": {
"tags": []
}
}
}
....
]
}
我想只更新与我作为ObjectID传入的对象匹配的对象的特定标记。更新一堆匹配特定ObjectID的对象值的最佳方法是什么?
您可以使用经过过滤的位置操作符$[arrayFilters
条件的数组元素,以进行更新操作。
- 如果您在每个节点id中更新相同的标签,请尝试
$in
条件,否则您可以使用bulkWrite()
操作。
let value = ["tag1", "tag2"];
let nodes = [
ObjectId("6022bc959b559276bd39f4be"),
ObjectId("7022bc959b559276bd39f4ce")
];
db.collection(collection).updateOne(
{},
{ $set: { "projectData.nodes.$[d].data.nodeData.tags": value } },
{
arrayFilters: [
{ "d.data._id": { $in: nodes } }
]
}
)
游乐场
为了完整起见,我想添加我自己的解决方案。基于可接受的答案,我构建了以下操作,因为每个节点可能有不同的标记,并且我希望每次都能够添加标记:
const ObjectID = require('mongodb').ObjectID;
nodes.forEach(node => {
updateOneObjectWithTags(db, node._id, "projectData.nodes.$[d].data.nodeData.tags", node.nodeData.tags, "d.data._id", collection).then(result => {
console.log(result);
});
});
updateOneObjectWithTags: (db, objectId, updateKey, updateValue, arrayFilterKey, collection) => {
return new Promise((resolve, reject) => {
db.collection(collection).updateOne(
{},
{
$set: {
[updateKey] : updateValue
}
},
{
arrayFilters: [
{
[arrayFilterKey]: new ObjectID(objectId)
}
]
})
resolve(true);
});