簡體   English   中英

howto節點module.exports

[英]howto Node module.exports

我想分離用於在Node中執行mysql查詢的代碼,因此我嘗試在此處使用“顯示模塊”模式

/* pool  -create connection pool mysql*/
var sqlQuery = function (sqlString) {
    var _result = pool.getConnection(function (err, connection) {
/* error handling*/
    connection.query(sqlString, function (err, rows) {
        console.log(this.sql);
        if (!err) {
           return _result = rows; <============
        } 
        connection.release();
    });
    return;
    });
    console.log(_result);
    return { recordSet : _result }
};
module.exports = sqlQuery;

如何將行返回到我的app.js。 以下用於調用sqlQuery的代碼不起作用

var SqlQuery = require(./path/to/sqlQueryFile);
var rows = SqlQuery('pass sql here').recordSet;
console.log(row);
res.json(rows);

您的代碼是異步的,但是您正在同步調用它。

如果您想這樣做,還需要將回調傳遞給SqlQuery

/* pool  -create connection pool mysql*/
var sqlQuery = function (sqlString, callback) {
    var _result = pool.getConnection(function (err, connection) {
    /* error handling*/
      connection.query(sqlString, function (err, rows) {
        console.log(this.sql);
        if (!err) {
          callback(rows);
        } 
        connection.release();
      });
  });
};
module.exports = sqlQuery;

然后調用:

var SqlQuery = require(./path/to/sqlQueryFile);
var rows = SqlQuery('pass sql here', function(recordSet){
  console.log(recordSet);
  res.json(recordSet);
});

編輯:如果您使用的是JavaScript的較新版本,則還有更多選擇。

如果您可以訪問Promises,則可以執行以下操作:

function sqlQuery (sqlString) {
  return new Promise((resolve, reject) => {
    pool.getConnection(function (err, connection) {
      if (err) { return reject(err); } // error handling
      connection.query(sqlString, function (err, rows) {
        if (err) { return reject(err); }
        resolve(rows);
        connection.release();
      });
    });
  });
}
module.exports = sqlQuery;

然后您可以像這樣使用它:

var SqlQuery = require(./path/to/sqlQueryFile);
SqlQuery('pass sql here')
  .then(function(recordSet) {
    console.log(recordSet);
    res.json(recordSet);
  })
  .catch(function(err) {
    // do your error handling
    res.status(500).json({ err: 'Sorry there was an error' });
  });

如果您使用的是更新的 JavaScript,則可以使用async / await語法(當前可通過Babel使用,我認為在FireFox中可用。在V55中為Chrome)。

var SqlQuery = require(./path/to/sqlQueryFile);
async handleQuery(query) {
  try {
      var rows = await SqlQuery(query);
      res.json(rows);
  } catch (e) {
    console.log('Error!', e);
  }
}

要將多個查詢鏈接在一起:

async handleQuery(query) {
  try {
      return await SqlQuery(query);
  } catch (e) {
    console.log('Error!', e);
  }
}

var rows = await handleQuery('select * from tablename');
var rowsToReturn = await handleQuery('select id from another_table where name = "' + rows[0].name + '"');

暫無
暫無

聲明:本站的技術帖子網頁,遵循CC BY-SA 4.0協議,如果您需要轉載,請注明本站網址或者原文地址。任何問題請咨詢:yoyou2525@163.com.

 
粵ICP備18138465號  © 2020-2024 STACKOOM.COM