Ho questa funzione:
var getTexts = new cronJob( '*/1 * * * *', function(){
var viewConformationEmails = "select * from clients";
ibmdb.open(ibmdbconn, function(err, conn) {
if (err) return console.log(err);
conn.query(viewConformationEmails, function(err, rows) {
if (err) {
console.log(err);
} else if (!err) {
console.log("Success")
}
for (var i = 0; i < rows.length; i++) {
// arrayOfNumbers.push(rows[i].NAME)
// arrayOfNumbers.push(rows[i].PHONE_NUMBER)
// arrayOfNumbers.push(rows[i].HOUR)
// arrayOfNumbers.push(rows[i].MINUTE)
var minute = rows[i].MINUTE;
var hour = rows[i].HOUR;
console.log(rows[i])
var stringg = rows[i]["MINUTE"] + " " + rows[i]["HOUR"] + " * " + "* " + "*"
var textJob = new cronJob( stringg, function(){
client.messages.create( { to:'xxx', from:'yyy', body:'Hello! Hope you’re having a good day!' }, function( err, data ) {});
}, null, true);
}
conn.close(function() {
});
});
});
}, null, true)
che cosa si dovrebbe fare è eseguire un cronjob ogni 1 minuti, che prende tutti i risultati dal mio clients
tabella. Ho poi loop attraverso ogni risultato, e se è l'ora corrente e le partite momento nel database, quindi invia il messaggio. tuttavia, si corre il primo cronjob a ogni minuto della giornata, e quindi diciamo che il mio etxt dovrebbe andare il nostro alle 9:15, quindi non può arrivare abbastanza in fretta, perché è ancora in corso attraverso il primo cronjob itteration. Ecco la mia ipotesi, ma non ne sono sicuro al 100% e non riesco a capire il perché. Qualcuno può aiutare?