我在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}})
答案 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);
}
});
看看这是否可以帮到你。