Я знаю, что этот вопрос уже задавался, но это другой сценарий.
Я хотел бы иметь такую коллекцию:
{
"_id" : ObjectId("4c28f62cbf8544c60506f11d"),
"pk": 1,
"forums": [{
"pk": 1,
"thread_count": 10,
"post_count": 20,
}, {
"pk": 2,
"thread_count": 5,
"post_count": 24,
}]
}
Что я хочу сделать, это добавить элемент «форум», увеличить счетчики или добавить элемент, если он не существует.
Например, сделать что-то вроде этого (надеюсь, это имеет смысл):
db.mycollection.update({
"pk": 3,
"forums.pk": 2
}, {
"$inc": {"forums.$.thread_count": 1},
"$inc": {"forums.$.post_count": 1},
}, true)
и имеют:
{
"_id" : ObjectId("4c28f62cbf8544c60506f11d"),
"pk": 1,
"forums": [{
"pk": 1,
"thread_count": 10,
"post_count": 20,
}, {
"pk": 2,
"thread_count": 5,
"post_count": 24,
}]
},
{
"_id" : ObjectId("4c28f62cbf8544c60506f11e"),
"pk": 3,
"forums": [{
"pk": 2,
"thread_count": 1,
"post_count": 1,
}]
}
Конечно, я могу сделать это в три этапа:
- Добавить всю коллекцию с новым предметом
- addToSet элемент форума в списке
- увеличение счетчиков элементов форума с позиционным оператором
То есть:
db.mycollection.update({pk:3}, {pk:3}, true)
db.mycollection.update({pk:3}, {$addToSet: {forums: {pk:2}}})
db.mycollection.update({pk:3, 'forums.pk': 2}, {$inc: {'forums.$.thread_counter': 1, {'forums.$.post_counter': 1}})
Вам известен более эффективный способ сделать это?
ТИА, Джермано