Направих търсене за същия въпрос, но все още не намерих решение. С асинхронната библиотека е много лесно да използвате заявката няколко пъти и да извършите необходимото обработване на грешки.
Може би този вариант на кода помага. (за вмъкване на 10 000 малки json обекта в празна база данни отне 6 секунди).
Кристоф
function insertData(item,callback) {
client.query('INSERT INTO subscriptions (subscription_guid, employer_guid, employee_guid)
values ($1,$2,$3)', [
item.subscription_guid,
item.employer_guid,
item.employee_guid
],
function(err,result) {
// return any err to async.each iterator
callback(err);
})
}
async.each(datasetArr,insertData,function(err) {
// Release the client to the pg module
done();
if (err) {
set_response(500, err, res);
logger.error('error running query', err);
return console.error('error running query', err);
}
logger.info('subscription with created');
set_response(201);
})