node.js – 基于id更新数组对象?

我有一个mongo问题.我想知道是否有办法在mongo控制台命令中执行以下操作,而不是多个查找和更新调用.

{
    "_id" : ObjectId("50b429ba0e27b508d854483e"),"array" : [
        {
            "id" : "1","letter" : "a"
        },{
            "id" : "2","letter" : "b"
        }
    ],"tester" : "tom"
}

我想用这个新的数组项更新对象

{
    "id": "2","letter": "c"
}

我使用它,addToSet是有限的,如果它已经存在,它将不会将项插入数组,但它不会根据标识符更新项.在这种情况下,我真的想根据id更新此条目.

db.soup.update({
     "tester": "tom"
 },{
     $addToSet: {
         "array": {
             "id": "2","letter": "c"
         }
     }
});

这给了我:

{
    "_id" : ObjectId("50b429ba0e27b508d854483e"),"letter" : "b"
        },"letter" : "c"
        }
    ],"tester" : "tom"
}

当我真正想要的是:

{
    "_id" : ObjectId("50b429ba0e27b508d854483e"),"tester" : "tom"
}

解决方法

您可以使用 $位置运算符来执行此操作:

db.soup.update(
    {_id: ObjectId("50b429ba0e27b508d854483e"),'array.id': '2'},{$set: {'array.$.letter': 'c'}})

update对象中的$充当数组的第一个元素的占位符,以匹配查询选择器.

相关文章

这篇文章主要介绍“基于nodejs的ssh2怎么实现自动化部署”的...
本文小编为大家详细介绍“nodejs怎么实现目录不存在自动创建...
这篇“如何把nodejs数据传到前端”文章的知识点大部分人都不...
本文小编为大家详细介绍“nodejs如何实现定时删除文件”,内...
这篇文章主要讲解了“nodejs安装模块卡住不动怎么解决”,文...
今天小编给大家分享一下如何检测nodejs有没有安装成功的相关...