Mysql
 sql >> Datenbank >  >> RDS >> Mysql

node.js und MySQL-Verbindungspool werden nicht exportiert

Sie exportieren eine Funktion, nicht den Pool selbst. Außerdem akzeptiert getConnection keinen Rückruf:

db.js sollte in etwa so aussehen:

var mySQL = require('mysql');
var pool  = mySQL.createPool({
    host: config.host,
    user: config.user,
    password: config.password,
    database: config.database
});
var getConnection = function (cb) {
    pool.getConnection(function (err, connection) {
        //if(err) throw err;
        //pass the error to the cb instead of throwing it
        if(err) {
          return cb(err);
        }
        cb(null, connection);
    });
};
module.exports = getConnection;

query.js sollte in etwa so aussehen:

var getConnection = require('./db');
getConnection(function (err, con) {
  if(err) { /* handle your error here */ }
  var userQuery = 'select * from user';
  console.log("con: " + con); //displays undefined
  con.query(userQuery,function(err,user){
  con.release();
});