Eu tenho esta função:
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)
o que ele deve fazer é executar um cron a cada 1 minuto, que recebe todos os resultados de minha clients
tabela. Eu, então, um loop através de cada resultado, e se é a hora actual e mathces o tempo em que o banco de dados e, em seguida, envia a mensagem. no entanto, corre-se o primeiro cron a cada minuto do dia e, em seguida, digamos que a minha etxt é suposto ir a nossa, às 9:15, então ele não pode chegar lá rápido o suficiente, porque ele é ainda de passar pelo primeiro cron itteration. Esse é o meu palpite, mas eu não tenho 100% de certeza e eu não consigo descobrir o porquê. Alguém pode me ajudar?