Node.js PostgreSQL请求被提前终止

Node.js PostgreSQL请求被提前终止,sql,node.js,postgresql,sql-update,Sql,Node.js,Postgresql,Sql Update,我试图使用节点对PostgreSQL数据库执行更新,但我收到一个错误:连接终止正在执行更新操作。我可能在以适当的异步方式处理连接时弄糟了,过早地终止了它们,但我不知道如何正确地执行 抱歉,代码太多了,但它非常简单 //main.js var result = require('./processes.js'); result.check(function(message) { console.log(message); }); result.decrease(); //Throws

我试图使用节点对PostgreSQL数据库执行更新,但我收到一个
错误:连接终止
正在执行
更新
操作。我可能在以适当的异步方式处理连接时弄糟了,过早地终止了它们,但我不知道如何正确地执行

抱歉,代码太多了,但它非常简单

//main.js
var result = require('./processes.js');
result.check(function(message) {
    console.log(message);

});

result.decrease(); //Throws an error.


//workers.js
var pg = require ('pg');
var fs = require('fs');

var db = JSON.parse(fs.readFileSync('../config.json', 'utf8')).db;
var querydb = require('./querydb.js');

var self = module.exports = {
    check: function(callback) {
        querydb.select("SELECT size FROM workers WHERE id = 1", function(results) {
            callback(results[0].size);
        });
    },
    increase: function() {
        self.check(function(workers) {
            querydb.update("UPDATE workers SET size = " + (workers + 1) + " WHERE id = 1");
        });
    },
    decrease: function() {
        self.check(function(workers) {
            querydb.update("UPDATE workers SET size = " + (workers - 1) + " WHERE id = 1");
        });
    }
};


//querydb.js
var pg = require ('pg');
var fs = require('fs');

var db = JSON.parse(fs.readFileSync('../config.json', 'utf8')).db;

var select = function(statement, callback) {
    pg.connect(db, function(err, client, done) {
        var results = [];
        //Handle errors
        if(err) {
            done();
            console.log(err);
        }
        var query = client.query(statement);

        //Stream results back
        query.on('row', function(row) {
            results.push(row);
        });

        //When all data is returned.
        query.on('end', function() {
            done();
            callback(results);
            client.end();
        });
    });
}

var update = function(statement) {
    pg.connect(db, function(err, client, done) {
        var results = [];
        //Handle errors
        if(err) {
            done();
            console.log(err);
        }
        var query = client.query(statement);

        //When all data is returned.
        query.on('end', function() {
            done();
            client.end();
        });
    });
}

module.exports = {
    select: select,
    update: update
};

好的,这本身可能不是一个答案,更像是一个解决办法,但对这种脚本(即不是web服务器)进行同步调用是我想要的行为,因此我最终选择了pg而不是pg,并重构了我的
querydb
workers
模块来使用它,现在一切都正常了

好的,这本身可能不是一个答案,更像是一个解决办法,但同步调用这种脚本(即不是web服务器)是我想要的行为,因此我最终选择了pg而不是pg,并重构了我的
querydb
workers
模块来使用它,现在一切都正常了

如果你改为使用,你就不会对连接感到头痛,因为它们会被自动处理。如果你改为使用,你就不会对连接感到头痛,因为它们会被自动处理。