使用了node-mysql的代码无法自动停止

发布于 2021-11-27 20:53:56 字数 1560 浏览 797 评论 2

// db.js
var mysql = require('mysql');

module.exports = function () {
    var pool = mysql.createPool({
        host: "localhost",
        user: 'xxx',
        password: 'xxx',
        database: 'xxx',
    });

    return pool;
}();


// valid.js
var pool = require('./db.js');

module.exports = function () {
    return {
        isProjectOwner: function (uid, pid, callback) {
            pool.getConnection(function (err, connection) {
                if (err) {
                    callback(err, null);
                }

                var sql = '.....';
                connection.query(sql, [pid, uid], function (err, res, fields) {
                    if (err) {
                        callback(null, false); // Maybe attack
                    }

                    console.log(res);

                    if (res.length) {
                        callback(null, true);
                    } else {
                        callback(null, false);
                    }

                    connection.release();
                });
            });
        },
    };
}();

// tdb.js
var valid = require('./valid.js');

valid.isProjectOwner(2, 1, function (err, result) {
    if (err) {
        throw err;
    }

    console.log(result);
});

在Terminal中运行

> $ node tdb.js
[]
false



但是,不使用ctrl+c无法结束进程,会一直等待。。。

求教各位大大,谢谢~~



如果你对这篇内容有疑问,欢迎到本站社区发帖提问 参与讨论,获取更多帮助,或者扫码二维码加入 Web 技术交流群。

扫码二维码加入Web技术交流群

发布评论

需要 登录 才能够评论, 你可以免费 注册 一个本站的账号。

评论(2

冬天旳寂寞 2021-11-28 16:50:47

连接池未关闭

心欲静而疯不止 2021-11-27 21:14:16

会不会是吃了炫迈口香糖?

~没有更多了~
我们使用 Cookies 和其他技术来定制您的体验包括您的登录状态等。通过阅读我们的 隐私政策 了解更多相关信息。 单击 接受 或继续使用网站,即表示您同意使用 Cookies 和您的相关数据。
原文