在我的node.js应用程序中,我使用mysql库进行数据库连接。
当我启动节点服务器时,我可以完全正确地查询数据库 - 没有问题
当我在5分钟后查询数据库时,服务器返回以下错误:
{"code":"PROTOCOL_ENQUEUE_AFTER_FATAL_ERROR","fatal":false}
如果我重启我的node.js服务器,我可以再次查询,没有问题......
这是我的代码
const mysql = require('mysql');
let connection = mysql.createPool({
host: config.mysql.host,
user: config.mysql.user,
password: config.mysql.password,
database: config.mysql.database
});
router.post('/subscription', (req, res) => {
const user = req.body;
const q = 'INSERT into Subscription SET ?';
connection.query(q, user, (err, results) => {
if (err)
return res.json(err);
return res.json(results);
});
});
我已经使用了mysql.createConnection和mysql.createPool ....还尝试使用connection.end ...。
手动结束连接两个结果都以相同的错误结束。
答案 0 :(得分:1)
您需要从池中获取连接并使用它,而不是查询池本身。当您从池中获得连接时,池将确保您从池中获得有效连接。所以你的代码是:
const mysql = require('mysql');
let pool = mysql.createPool({
host: config.mysql.host,
user: config.mysql.user,
password: config.mysql.password,
database: config.mysql.database
});
router.post('/subscription', (req, res) => {
const user = req.body;
const q = 'INSERT into Subscription SET ?';
pool.getConnection(function(err, connection) {
if (err)
return res.json(err);
connection.query(q, user, (err, results) => {
if (err)
return res.json(err);
return res.json(results);
});
})
});
<强>更新强>:
您不需要单独执行pool.getConnection和connection.query,您可以将它们组合到一个pool.query中,它将获得连接,执行查询并释放连接。因此,更新的代码将是:
const mysql = require('mysql');
let pool = mysql.createPool({
host: config.mysql.host,
user: config.mysql.user,
password: config.mysql.password,
database: config.mysql.database
});
router.post('/subscription', (req, res) => {
const user = req.body;
const q = 'INSERT into Subscription SET ?';
pool.query(q, user, function(err, connection) {
if (err)
return res.json(err);
return res.json(results);
});
});