简体   繁体   中英

Mongoose - How to push object in nested array of objects

I have this data structure in my MongoDb database:

    "menu": [
            {
                "dishCategory":"61e6089f209b802518e2b4a4",
                "dishMeals": [
                    {
                        "dishMealName": "Burger King",
                        "dishMealIngredients": "Burger lepinja, bbq sos, berlin sos, zelena"
                        "dishMealPrice": 5
                    }
                ]
            }
        ]

How do I push new object inside dishMeals in exact dishCategory ( I am providing dishCategory id, newDish object and _id of restaurant through req.body) I've tried this but nothing is changing:

     await Restaurants.updateOne(
            {
                '_id' : _id,
                'menu.dishCategory' : dishCategoryId
            },
            {
                $push : {
                    'menu.$.dishMeals' : newDish
                }
            }
        );
  1. Use arrayFilters to filter the nested document(s) in the array field, then $push if the filter criteria in the arrayFilters met.
db.collection.update({
  "_id": _id,
  "menu.dishCategory": dishCategoryId
},
{
  $push: {
    "menu.$[menu].dishMeals": newDish
  }
},
{
  arrayFilters: [
    {
      "menu.dishCategory": dishCategoryId
    }
  ]
})

Sample Mongo Playground

You can do it with arrayFilters config in update query:

db.collection.update({
  "restaurant_id": 1
},
{
  "$push": {
    "menu.$[element].dishMeals": {
      "dishMealName": "Best Burger",
      "dishMealIngredients": "Best burger in town",
      "dishMealPrice": 10
    }
  }
},
{
  "arrayFilters": [
    {
      "element.dishCategory._id": "61e6089f209b802518e2b4a4"
    }
  ]
})

Working example

You may read the question and the solution they provided here , Hope this one will be helpful to you.

db.collection.update({
    "_id": 1,
    "menu.dishCategory": "61e6089f209b802518e2b4a4"
},
{
    $push: {
        "menu.$.dishMeals": newMeal
    }
})

The technical post webpages of this site follow the CC BY-SA 4.0 protocol. If you need to reprint, please indicate the site URL or the original address.Any question please contact:yoyou2525@163.com.

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