【问题标题】:NodeJS and mysql: wait for query resultNodeJS 和 mysql:等待查询结果
【发布时间】:2015-10-24 20:16:51
【问题描述】:

我有一个用 nodejs + express 做的小项目,我还做了一个小服务,可以在它的一些页面上共享。

var mysql = require('mysql');

var pool = mysql.createPool({
        connectionLimit : 100,
        host     : 'host',
        user     : 'user',
        password : 'password',
        database : 'database',
        debug    : false
});

function executeQuery(query, callback) {
    pool.getConnection(function (err, connection) {
        if (err) {
            return callback(err, null);
        }
        else if (connection) {
            connection.query(query, function (err, rows, fields) {
                connection.release();
                if (err) {
                    return callback(err, null);
                }
                return callback(null, rows);
            })
        }
        else {
            return callback("No connection", null);
        }
    });
}


function getResult(query) {
    return executeQuery(query, function (err, rows) {
                if (!err) {
                    return rows;
                }
                else {
                    console.log(err);
                }
            });
}

function getServers()
{
    var list = getResult("select * from table");
    return list;
}

exports.getList = getList;

现在,我的问题是:当我调用 module.GetServers();从另一个模块,结果总是未定义,因为 pool.getConnection 是异步的(我想,我很新)所以 executeQuery 没有结果。 如何强制 executeQuery 等待 connection.query 产生结果?

【问题讨论】:

  • 请注意所有 nodejs 方法如何将回调函数作为参数 - 您需要在 getServers 函数中执行相同操作。然后,当您从查询中取回行时,调用回调,将行作为参数传递。

标签: mysql node.js asynchronous


【解决方案1】:

在您的 executeQuery 函数中,您使用了回调来等待结果。同样,通过在 getResult 函数中实现它们,您可以让它在查询执行后等待结果。像这样。

var mysql = require('mysql');
var pool = mysql.createPool({
    connectionLimit : 100,
    host     : 'host',
    user     : 'user',
    password : 'password',
    database : 'database',
    debug    : false 
 });

function executeQuery(query, callback) {
  pool.getConnection(function (err, connection) {
    if (err) {
        return callback(err, null);
    }
    else if (connection) {
        connection.query(query, function (err, rows, fields) {
            connection.release();
            if (err) {
                return callback(err, null);
            }
            return callback(null, rows);
        })
    }
    else {
        return callback(true, "No Connection");
    }
  });
}


function getResult(query,callback) {
  executeQuery(query, function (err, rows) {
     if (!err) {
        callback(null,rows);
     }
     else {
        callback(true,err);
     }
  });
}

function getServers() {
  getResult("select * from table",function(err,rows){
    if(!err){
        return rows;
    }else{
        console.log(err);
    }
  });   
}

exports.getList = getList;

【讨论】:

  • var getResult = executeQuery;
猜你喜欢
  • 2019-04-19
  • 1970-01-01
  • 2020-06-19
  • 2017-10-30
  • 2020-06-07
  • 1970-01-01
  • 1970-01-01
  • 2019-04-02
  • 1970-01-01
相关资源
最近更新 更多