繁体   English   中英

如何更新 mongdb 文档数组中 object 的特定项目

[英]How to update specific item of object in array of mongdb document

假设我们有以下集合,我对此几乎没有疑问:

{
    "_id" : ObjectId("4faaba123412d654fe83hg876"),
    "user_id" : 123456,
    "total" : 100,
    "items" : [
            {
                    "item_name" : "my_item_one",
                    "price" : 20
            },
            {
                    "item_name" : "my_item_two",
                    "price" : 50
            },
            {
                    "item_name" : "my_item_three",
                    "price" : 30
            }
    ]
}

在这种情况下,我必须一次更新 item_name OR price 或者同时更新两者。

例如:如果我在 req.body 中提供 item_name 那么它应该只更新 item_name 并且价格保持不变但是如果我提供价格那么它应该反之亦然。

基本上,我的意思是说它应该只更新 req.body 中提供的那个字段。

我试过这个

const result = await User.updateOne(
  {
    user_id: 123456,
    'items.item_name': 'my_item_two',
  },
  { $set: { items: req.body } }
)

但这与我想要的一样,但它正在删除已经存在的剩余字段!

我认为您可以在 JS 中创建$set object 然后将其传递给查询,如下所示:

 // body is to mock req.body const body_1 = { item_name: "new_name", price: 1 } const body_2 = { item_name: "new_name_2" } const body_3 = { price: 2 } const getSetObject = (body) => { update = { $set: {} } Object.keys(body).forEach(k => { update.$set[`items.$.${k}`] = body[k] }) return update } console.log(getSetObject(body_1)) console.log(getSetObject(body_2)) console.log(getSetObject(body_3))

请注意这是如何创建这些查询中使用的对象的:

所以你可以创建查询:

const result = await User.updateOne(
  {
    user_id: 123456,
    'items.item_name': 'my_item_two',
  },
  setObj
)

暂无
暂无

声明:本站的技术帖子网页,遵循CC BY-SA 4.0协议,如果您需要转载,请注明本站网址或者原文地址。任何问题请咨询:yoyou2525@163.com.

 
粤ICP备18138465号  © 2020-2024 STACKOOM.COM