节点js:mssql [ConnectionError:Connection is closed。] name:'ConnectionError',message:'Connection is closed。',code:'ECONNCLOSED'

时间:2016-01-27 13:19:51

标签: express node-mssql

我在使用sqlserver 2012的npm mssql 3.0.0中收到错误

我正在创建单页应用程序,我使用express来使用restful。 有4个方法执行查询并将数据返回到响应。 对于每种方法,我打开连接并关闭连接。

但是当savedquery正在调用时,会发生连接关闭错误。

每个方法代码类似于savedquery方法(复制粘贴代码只有查询被更改)但是它们正在执行savedquery没有执行

{[ConnectionError:连接已关闭。   名称:'ConnectionError',   消息:'连接已关闭。',   代码:'ECONNCLOSED'}

var savedquery=function(req,res){
       dbConfig= {
                user: 'XXX',
                password: 'XXXXXXXXXX',
                server: 'localhost', // You can use 'localhost\\instance' to connect to named instance 
                database: 'DEMO_ODS',       
                options: {
                    encrypt: true
                }
            };

        sql.connect(dbConfig).then(function (err) {
                var sqlrequest = new sql.Request();
                sqlrequest.query("SELECT * from SavedQuery").then(function (recordset) {
                    sql.close(function (value) {
                      console.log("connection6 closed");
                    });
                    return res.status(200).send(recordset);

                }).catch(function (err) {
                    console.log(err);
                });
            }).catch(function (err) { 
                console.log(err);
            });
        };
}

3 个答案:

答案 0 :(得分:2)

你应该删除

        options: {
            encrypt: true
        }
来自dbConfig的

答案 1 :(得分:2)

我知道这是一个古老的问题,但这个答案适用于面临同样问题的其他人。我有同样的问题,我做的是,使用如下的承诺。

    function getData() {
    try {
        sqlInstance.connect(setUp)
            .then(function () {
                // Function to retrieve all the data - Start
                new sqlInstance.Request()
                    .query("select * from Course")
                    .then(function (dbData) {
                        if (dbData == null || dbData.length === 0)
                            return;
                        console.dir('All the courses');
                        console.dir(dbData);
                    })
                    .catch(function (error) {
                        console.dir(error);
                    });

                // Function to retrieve all the data - End

                // To retrieve specicfic data - Start
                var value = 1;
                new sqlInstance.Request()
                    .input("param", sqlInstance.Int, value)
                    .query("select * from Course where CourseID = @param")
                    .then(function (dbData) {
                        if (dbData == null || dbData.length === 0)
                            return;
                        console.dir('Course with ID = 1');
                        console.dir(dbData);
                    })
                    .catch(function (error) {
                        console.dir(error);
                    });
                // To retrieve specicfic data - End

            }).catch(function (error) {
                console.dir(error);
            });
    } catch (error) {
        console.dir(error);
    }
}

这解决了我的问题。您可以找到修复here

答案 2 :(得分:0)

我只是使用promise处理并发请求:

const executeQuery = function (res, query, dbName) {

    dbConfig = {
        user: "********",
        password: "********",
        server: "*******",
        database: dbName
    }

    sql.connect(dbConfig).then(pool => {

        return pool.request().query(query)

    }).then(result => {

        res.send(result);

        }).catch(err => {

            res.send(err);


    });
}

希望对您有所帮助。