So che questa domanda è stata fatta prima, ma quello è uno scenario diverso. Mi piacerebbe avere una collezione come questa:C'è un modo per spostare un elenco con una singola query?
{
"_id" : ObjectId("4c28f62cbf8544c60506f11d"),
"pk": 1,
"forums": [{
"pk": 1,
"thread_count": 10,
"post_count": 20,
}, {
"pk": 2,
"thread_count": 5,
"post_count": 24,
}]
}
Quello che voglio fare è quello di upsert un elemento di "forum", incrementando contatori o l'aggiunta di un elemento se non esiste.
Ad esempio, per fare qualcosa di simile (spero abbia senso):
db.mycollection.update({
"pk": 3,
"forums.pk": 2
}, {
"$inc": {"forums.$.thread_count": 1},
"$inc": {"forums.$.post_count": 1},
}, true)
e avere:
{
"_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,
}]
}
posso sicuramente farlo in tre fasi:
- Upsert l'intera raccolta con un nuovo articolo
- addToSet l'elemento del forum alla lista contatori
- incremento voce forum con operatore posizionale
Vale a dire:
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}})
Sei a conoscenza di un modo più efficiente per farlo? TIA, Germano
Sì, l'ho capito. Grazie comunque. – Germano