我正在使用节点模块" node-mssql"连接SQL Server。
我创建了一个蓝鸟承诺,最后这个承诺关闭了连接。我这样做是因为我不知道如何建立主要连接,但我不认为打开/关闭连接每个查询都是个好主意。
function connection() {
let promise = sql.connect('...');
promise.catch(function (err) {
console.log('********** Error on connecting **********');
console.log(err);
console.log('---------- Error on connecting ----------');
})
.finally(function () {
sql.close();
});
return promise;
};
var query = connection().then(function() {
new sql.Request()
.input('foo', mssql.NVarChar, 'bar')
.query('...')
.then(function (out) {
//...
})
.catch(function (err) {
console.log('********** Error on query **********');
console.log(err);
console.log('---------- Error on query----------');
});
});
有没有办法建立主要连接?
答案 0 :(得分:0)
嗯......我解决了这个添加标志和功能,在我的代码下面,我希望它有所帮助,或者评论是否有更好的方法。
var mssql = require('mssql');
var sql = {}
sql.connected = false;
sql.connect = function () {
let promise = mssql.connect(SQL.String);
promise.catch(function (err) {
// handling error
mssql.close();
sql.connected = false;
});
return promise;
};
sql.Request = function () {
return new Promise(function (resolve, reject) {
if (!sql.connected) {
sql.connect()
.then(function () {
sql.connected = true;
resolve(new mssql.Request());
});
} else {
resolve(new mssql.Request());
}
});};