Mam tabeli ankietę, która wygląda tak:RethinkDB - Aktualizacja zagnieżdżonego tablicę
{
id: Id,
date: Date,
clients: [{
client_id: Id,
contacts: [{
contact_id: Id,
score: Number,
feedback: String,
email: String
}]
}]
}
Ptrzebuję aktualizowanych pól score
i feedback
ramach określonego kontaktu. Obecnie używam aktualizację tak:
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;
};
Kiedy patrzę na metodzie update, określa jak zaktualizować klucz zagnieżdżone: par wartości. Jednak nie mogę znaleźć żadnych przykładów aktualizacji pojedynczego elementu w tablicy.
Czy istnieje lepszy i miejmy nadzieję czystszy sposób aktualizowania elementów w zagnieżdżonej tablicy?