据我了解,这是一个stream
,所以它不断地向Oracle数据库传输值。节点超时功能?
我想知道如果我可以做一个超时功能等待大约3秒后再次发送。
var net = require('net');
var fs = require('fs');
var oracledb = require('oracledb');
var dbConfig = require('./dbconfig.js');
var client = new net.Socket();
client.connect(8080, "192.168.0.7");
console.log("Client most likely connected...");
oracledb.getConnection(
{
user : dbConfig.user,
password : dbConfig.password,
connectString : dbConfig.connectString
},
function(err, connection) {
if (err) {
console.error(err.message);
return;
}
client.on('data', function (data) {
var weight_data = Number(data);
console.log('Data: ' + data);
connection.execute("INSERT INTO UNI_SCRAP_SCALE(WEIGHT) VALUES (:weight)", [weight_data], function (err, result) {
if (err) throw err;
console.log("Rows inserted: " + result.rowsAffected);
console.log('Data received from Db:\n');
console.log(result);
connection.commit(
function (err) {
console.log('Done')
});
});
});
});
});
// client.destroy();
所以我把setTimeout的在3个不同的地点。如果connection.execute位于setTimeout块内,则会出现错误,说明需要回调。所以我试着把它放在3个console.logs的下面,它在那个代码上等了3秒,然后开始执行,就好像setTimeout不再存在一样(我想setTimeout只是一次)。显然,Node是一个糟糕的选择。也许使用套接字也是一个不错的选择。 –