使用mongodb更新中的一个变量

using a variable in mongodb update

本文关键字:一个 变量 mongodb 更新 使用      更新时间:2023-09-26

使用Meteor,我正在尝试执行如下更新:

Items.update(Session.get('selectedItem'), {'$set': {'directions.0.name': area.value}})

但我很难动态设置方向的数组索引,比如

var index = //a value determined dynamically
Items.update(Session.get('selectedItem'), {'$set': {'directions[index]name': area.value}})

这不起作用,因为[index]被包裹在一个字符串中。我还试图形成一个自定义字符串,如下所示:

var string = 'directions.'+itemIndex+'.name'
Items.update(Session.get('selectedItem'), {'$set': {string: area.value}})

但这行不通。你知道怎么做吗?

您需要以编程方式构建$set对象:

var setModifier = { $set: {} };
setModifier.$set['directions.' + index + '.name'] = area.value;
Items.update(Session.get('selectedItem'), setModifier);

更新

如果您的JavaScript环境支持计算属性名称(例如node.js4+),您可以通过一个步骤完成:

Items.update(Session.get('selectedItem'), { $set: {
    ['directions.' + index + '.name']: area.value
}});