【问题标题】:Update a field in mongodb document stored in a array of array in yii2 model更新存储在 yii2 模型数组中的 mongodb 文档中的字段
【发布时间】:2016-06-29 10:26:21
【问题描述】:

我在 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}})

【问题讨论】:

  • 你能告诉我们你为实现它所做的努力吗?
  • @Shrabanee 我已经用我尝试过的查询更新了我的问题。

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


【解决方案1】:

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

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

看看这对你有没有帮助。

【讨论】:

  • 这个查询我之前尝试过,它给出了这个错误Too many positional (i.e. '$') elements found in path 'menu.menuCategory.$.menuItems.$.likesCount'
  • 是的,我试过了。 0 将给出数组中的第一个对象,因为在 $ 的两种情况下,所需的对象都不是必须位于 0 th 位置
  • 否 它不起作用,查询正在执行且没有任何错误,但我的数据库中没有针对 menuId 的更新。在上述查询中,以) 结束,并在x 的赋值语句末尾添加语句分隔符; 而不是,
  • 你可以试试调试吗?哪里出错了?理想情况下它应该工作。这就是我的使用方式,在我的情况下它运行良好。
  • 我尝试调试,但没有发现错误。请告诉我您正在遵循的程序。
猜你喜欢
  • 2021-07-20
  • 2020-01-03
  • 1970-01-01
  • 2021-07-24
  • 2016-02-15
  • 1970-01-01
  • 2016-12-18
  • 1970-01-01
  • 2018-12-08
相关资源
最近更新 更多