Ho una tabella sondaggio che assomiglia così:RethinkDB - Aggiornamento array nidificato
{
id: Id,
date: Date,
clients: [{
client_id: Id,
contacts: [{
contact_id: Id,
score: Number,
feedback: String,
email: String
}]
}]
}
devo aggiornati i campi score
e feedback
sotto un contatto specifico. Attualmente, sto facendo funzionare l'aggiornamento in questo modo:
function saveScore(obj){
var dfd = q.defer();
var survey = surveys.get(obj.survey_id);
survey
.pluck({ clients: 'contacts' })
.run()
.then(results => {
results.clients.forEach((item, outerIndex) => {
item.contacts.forEach((item, index, array) => {
if(Number(item.contact_id) === Number(obj.contact_id)) {
array[index].score = obj.score;
console.log(outerIndex, index);
}
});
});
return survey.update(results).run()
})
.then(results => dfd.resolve(results))
.catch(err => dfd.resolve(err));
return dfd.promise;
};
Quando guardo il metodo update, specifica come aggiornare chiave annidati: coppie di valori. Tuttavia, non riesco a trovare alcun esempio per aggiornare un singolo elemento in un array.
C'è un modo migliore e, auspicabilmente, più pulito per aggiornare gli elementi in un array annidato?