将繁琐的连接作为参数

时间:2018-09-10 21:48:46

标签: sql node.js tedious

我正在尝试使用通过Tedious库构建的一组简单功能来访问Microsoft SQL Server。这是我的“工具”文件:

'use strict';
const tedious = require('tedious');
const q = require('q');

var Connection = tedious.Connection;
var Request = tedious.Request;

module.exports = {

    connectSQL : function(config) {

        var connection = new Connection(config);

        connection.on('connect', function(err) {
            if (err) {
                console.log('FAIL ON CONNECT');
                console.log(err);
            } else {
                try {
                    /* ----- */
                    return connection;
                } catch (err) {
                    console.log(err);
                    return;
                }
            }
        });

        connection.on('error', function(err) {

           if (err) {
                console.log('FAIL ON ERROR');
                console.log(err);
            } else {
                console.log("Error called with no err object.");
            }
        });

    },

    executeSQL: function(connection, requestString) {

        var results = [];

        var request = new Request( requestString , function(err, data) {
            if (err) {
                console.log(err);
            } else {
                console.log( data );
            }

        });

        request.on('row', function(row) {
            //console.log(row);
            results.push( row );

        });

        request.on('requestCompleted', function(){
            console.log('Finished');
            return results;
        });

        connection.execSql(request);
    }
}

我在服务器文件中按以下方式调用这些函数。

const sqlTools = require('./sqlTools.js');

var connection = sqlTools.connectSQL(config);

sqlTools.executeSQL(connection, "select * from dbo.test");

但是,即使我在调用函数sqlTools.executeSQL之前使程序休眠了10秒钟,也会收到错误消息“ TypeError:无法读取未定义的'execSql'”(显然不理想)。

我能够通过在sqlTools.connectSQL函数(在“ / * ----- * /”处)中调用请求来使其工作,但是我想重新使用Tedious连接来建立多个连接电话。有什么建议么?谢谢!

~~~~~~~编辑~~~~~~~~~~

在akinjide的帮助下,我能够实现回调,使我可以对SQL数据库进行一次调用。但是,我正在努力兑现诺言以进行后续通话。我这样更改了“工具”文件:

'use strict';
const tedious = require('tedious');
const q = require('q');

var Connection = tedious.Connection;
var Request = tedious.Request;

module.exports = {

    connectSQL: function(config) {

        var deferred = q.defer();
        var connection = new Connection(config);

        connection.on('connect', function(err) {
            if (err) {
                deferred.reject( err );
            } else { 
                deferred.resolve( connection );
            }
        });

        connection.on('error', function(err) {
            deferred.reject(err);
        });

        return deferred.promise;
    },


    executeSQL: function(connection, requestString, callback) {

        var results = [];

        const request = new Request(requestString, function(err) {

            callback(err);

        });

        request.on('row', function(row) {

            results.push(row);

        });

        request.on('requestCompleted', function() {

            console.log('request completed!');
            callback(null, results);

        });

        connection.execSql(request);
    }
}

我这样称呼这段代码...

var promise = sqlTools.connectSQL(config);

promise.then(function (connection) {
    sqlTools.executeSQL(connection, "select * from dbo.test", function(err, results) {

      if (err) {
        console.log(err);
      }

      console.log(results);

    });

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

    sqlTools.executeSQL(connection, "select * from dbo.test2", function(err, results) {

      if (err) {
        console.log(err);
      }

      console.log(results);

    });

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

这将正确返回第一个调用的结果,但是不幸的是,第二个调用返回此错误“ TypeError:无法读取未定义的'execSql'属性”,因为它第二次无法识别连接。有什么建议吗?

1 个答案:

答案 0 :(得分:0)

更好的方法是将node.js回调样式函数作为参数传递给return

'use strict'; const tedious = require('tedious'); const Connection = tedious.Connection; const Request = tedious.Request; module.exports = { connectSQL: function(config, callback) { const connection = new Connection(config); connection.on('connect', function(err) { if (err) { callback(err); } else { callback(null, connection); } }); connection.on('error', function (err) { callback(err); }); }, executeSQL: function(connection, requestString, callback) { let results = []; const request = new Request(requestString, function(err) { callback(err); }); request.on('row', function(row) { results.push(row); }); request.on('requestCompleted', function(){ console.log('Finished'); callback(null, results); }); connection.execSql(request); } } 关键字在异步程序中不起作用。

sqlTools.connectSQL

然后您可以要求使用config传递两个参数function(err, connection) {}const sqlTools = require('./sqlTools'); sqlTools.connectSQL(config, function(err, connection) { if (err) { console.log('FAIL ON CONNECT'); console.log(err); } sqlTools.executeSQL(connection, "select * from dbo.test", function (err, results) { if (err) { console.log(err); } console.log(results); }); });

{{1}}