Obsługa asynchronicznych zapytań do bazy danych w node.js i mongodb
Mam ten problem z pytaniem o mongodb asynchronicznie z node.js. Oto mój kod
var values = [];
var positives = new Array();
var negatives = new Array();
var server1 = new mongodb.Server('localhost',27017, {auto_reconnect: true});
var db1 = new mongodb.Db('clicker', server1);
db1.open(function(err, db) {
if(!err) {
db1.collection('feedback', function(err, collection) {
for (var i=0;i <5; i++) {
collection.find(
{value:1},
{created_on:
{
$gte:startTime + (i*60*1000 - 30*1000),
$lt: startTime + (i*60*1000 + 30*1000)
}
},
function(err_positive, result_positive) {
result_positive.count(function(err, count){
console.log("Total matches: " + count);
positives[i] = count;
});
}
);
collection.find(
{value:0},
{created_on:
{
$gte:startTime + (i*60*1000 - 30*1000),
$lt: startTime + (i*60*1000 + 30*1000)
}
},
function(err_negative, result_negative) {
result_negative.count(function(err, count){
console.log("Total matches: " + count);
negatives[i] = count;
});
}
);
}
});
} else {
console.log('Error connecting to the database');
}
});
Właściwie próbuję uzyskać pewne wartości z bazy danych. A potem muszę manipulować tymi wartościami. Po prostu muszę odjąć liczbę ujemną od liczby dodatniej, a następnie zainicjować tablicę wartości z ujemną liczbą dodatnią. Teraz, ponieważ wyniki są uzyskiwane asynchronicznie. Jak mam manipulować tymi wartościami i umieszczać je w tablicy wartości.