更新存储在yii2模型中的数组数组中的mongodb文档中的字段

时间:2016-06-29 10:26:22

标签: php mongodb mongodb-query yii2-advanced-app database

我在mongodb有一个餐馆数据库。示例数据库如下。

{
   "restaurantId":"1",
   "menu":
   {
        "menuCategory":
        [
            {
                "menuCategoryId":"12"
                "menuItems":
                [
                    {
                        "menuId":"123",
                        "likesCount":0
                    },
                    {
                        "menuId":"1234",
                        "likesCount":0
                    }
                ]
            },
            {
                "menuCategoryId":"1290"
                "menuItems":
                [
                    {
                        "menuId":"2222",
                        "likesCount":0
                    },
                    {
                        "menuId":"3333",
                        "likesCount":0
                    }
                ]
            }
        ]
   }
}

在本文档中,我必须根据yii2中收到的menuId和restaurantId增加或减少喜欢计数。我无法找到餐厅中特定menuId的喜欢计数来更新它。

我尝试了以下查询来更新likesCount。

db.restaurants.update({$and:[{"restaurantId":"1"},{"menu.menuCategory.menu.menuId":"123"}]}, {$set:{"likesCount":5}})

1 个答案:

答案 0 :(得分:0)

此查询可能会对您有所帮助: -

db.restaurants.update(
{$and:[{"restaurantId":"1"},
{"menu.menuCategory.menuItems.menuId":"123"}]}, 
{$set:{"menu.menuCategory.0.menuItems.0.likesCount":5}})

修改

尝试以下内容: -

 db.restaurants.find(
 {"restaurantId":"1","menu.menuCategory.menuItems.menuId":"123"}).toArray(
function(err, result)
{
    var index,found = false;
  for(var j in result[0].menu.menuCategory){
    for(var i in result[0].menu.menuCategory[j].menuItems)
    {
         if(results[0].menu.menuCategory[j].menuItems[i].menuId == "123")
         {
            found = true;
            index = i;
            break;
        }  
     }}

  if(found)
  {
       var x = 'menu.menuCategory.$.menuItems.'+index+'.likes';

       var  updateObject = {$set : {}};    
       updateObject['$set'][x] = 5;

      db.restaurants.update(
    {"restaurantId":"1",
   "menu.menuCategory.menuItems.menuId":"123"}, updateObject);
  }
});

看看这是否可以帮到你。