doushe7934 2016-06-29 10:26
浏览 223

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

I have a database in mongodb for restaurants. Sample database is as follows.

{
   "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
                    }
                ]
            }
        ]
   }
}

In this document, I have to either increase or decrease the likes count against the menuId and restaurantId which is received in yii2. I am not able to find the likes count for the particular menuId in the restaurant to update it.

I tried the following query to update the likesCount.

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

1条回答 默认 最新

  • dongxu1668 2016-06-30 04:59
    关注

    This query may help you:-

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

    EDIT

    Try something like below:-

     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);
      }
    });
    

    See if this can help you.

    评论

报告相同问题?

悬赏问题

  • ¥15 gwas 分析-数据质控之过滤稀有突变中出现的问题
  • ¥15 没有注册类 (异常来自 HRESULT: 0x80040154 (REGDB_E_CLASSNOTREG))
  • ¥15 知识蒸馏实战博客问题
  • ¥15 用PLC设计纸袋糊底机送料系统
  • ¥15 simulink仿真中dtc控制永磁同步电机如何控制开关频率
  • ¥15 用C语言输入方程怎么
  • ¥15 网站显示不安全连接问题
  • ¥15 51单片机显示器问题
  • ¥20 关于#qt#的问题:Qt代码的移植问题
  • ¥50 求图像处理的matlab方案