微信公众号搜"智元新知"关注
微信扫一扫可直接关注哦!

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对象中的$充当数组的第一个元素的占位符,以匹配查询选择器.

版权声明:本文内容由互联网用户自发贡献,该文观点与技术仅代表作者本人。本站仅提供信息存储空间服务,不拥有所有权,不承担相关法律责任。如发现本站有涉嫌侵权/违法违规的内容, 请发送邮件至 dio@foxmail.com 举报,一经查实,本站将立刻删除。

相关推荐