繁体   English   中英

ReferenceError:nodejs 中未定义连接

[英]ReferenceError: connection is not defined in nodejs

两个 .js 文件都在同一个文件夹中。 我正在尝试运行该应用程序,但我收到该连接未在 user.js 中定义。 在连接上调用查询的那一行,它说它没有定义。

索引.js

var exports = module.exports = {};

var user = require('./user');

exports.User = user;
exports.startCon = startCon;

var mysql = require('mysql2');

function startCon() {
    return mysql.createConnection({
        host: 'localhost',
        user: 'root',
        password: 'root',
        database: 'users'
    })
}

用户.js

var dal = require('./index');

function User(){
    this.connection = null;
}

User.prototype.getAll = function(cb){
      this.connection = dal.startCon();

      connection.query('SELECT * FROM user;', function (error, data) {
        if(!error){
                cb(null, data);
        }
        else {
                console.log("Error Selecting : %s ", error );
                cb(error);
        }
    });

    connection.end();
}

module.exports = User;

尝试在回调函数中关闭连接

callback() {
    connection.close()
}

这个模块真的很奇怪

您需要在函数内部构造连接实例

var mysql = require('mysql');

let doSmth = function(userId) {

    let connection = mysql.createConnection({
        host     : 'localhost',
        user     : 'root',
        password : '',
        database : 'test'
    });
        return new Promise((resolve, reject) => {

        connection.query({
                sql: 'SELECT `address` FROM `User` WHERE `user_id` = ?'
            },
            [userId],
            function (error, results, fields) {
                console.log(error, results)
                if(!error) {
                    var obj = JSON.parse(JSON.stringify(results));
                    resolve(obj)
                } else {
                    reject(error)
                }
            }
        );
    })
}
module.exports = {
    doSmth
};

暂无
暂无

声明:本站的技术帖子网页,遵循CC BY-SA 4.0协议,如果您需要转载,请注明本站网址或者原文地址。任何问题请咨询:yoyou2525@163.com.

 
粤ICP备18138465号  © 2020-2024 STACKOOM.COM