这篇文章主要介绍了Nodejs 连接 mysql时报Error: Cannot enqueue Query after fatal error错误的处理办法,需要的朋友可以参考下
Nodejs 连接 mysql时报Error: Cannot enqueue Query after fatal error错误的处理办法
一、nodejs连接mysql?
npm install mysql --save创建连接代码 db.js
//导入mysql连接包
const mysql = require('mysql');
let dbconfig ={
host: 'db_host',
user: 'db_user',
password: 'db_pass',
database: 'db_name',
debug: true
};
function handleDisconnection() {
db = mysql.createConnection(dbconfig);
db.connect(function (err) {
if (err) {
console.log('db connect error:' + err.message + "2秒后重连");
setTimeout(handleDisconnection, 2000);
}
});
db.on('error', function (err) {
console.log(err);
if (err.code === 'PROTOCOL_CONNECTION_LOST') {
console.log('db error执行重连:' + err.message);
handleDisconnection();
} else {
throw err;
}
});
db.querySync = function(sql) {
return new Promise(function(resolve, reject) {
db.query(sql, function(error, results, fields) {
if(error) reject(error);
else resolve({results, fields})
})
})
};
return db;
}
//创建连接conn
exports.db = handleDisconnection();二、Nodejs 连接 mysql时报错 Error: Cannot enqueue Query after fatal error
1.原配置参数
let dbconfig ={
host: 'db_host',
user: 'db_user',
password: 'db_pass',
database: 'db_name',
debug: true
};只要加上useConnectionPooling: true参数就可以了
2.新配置参数
let dbconfig ={
host: 'db_host',
user: 'db_user',
password: 'db_pass',
database: 'db_name',
useConnectionPooling: true,
debug: true
};补充:Node.js连接MySQL数据库报错
解决Node.js第一次连接MySQL数据库时出现[SELECT ERROR] - ER_NOT_SUPPORTED_AUTH_MODE: Client does not support authentication protocol requested by server; consider upgrading MySQL client的错误。
报错原因:mysql8.0以上的加密方式,Node.js还不支持。
解决方法:
进入mysql(cmd管理员模式)
1.第一步:启动mysql服务,可以通过net start mysql命令实现
2.第二步:在命令行输入:mysql -u用户名 -p密码,回车;
-h表示服务器名,localhost表示本地,-hlocalhost 可不输入;
-u为数据库用户名,root是mysql默认用户名;
-p为密码,如果设置了密码,可直接在-p后链接输入,如:-p123456,用户没有设置密码,显示Enter password时,直接回车即可。)
例子:mysql -hlocalhost -uroot -p123456,包含了密码会直接进入
3.进入后是这样的:

4.输入MySQL语句
先输入alter user 'root'@'localhost' identified with mysql_native_password by '123456';
出现:

再输入flush privileges;
出现:

问题解决了,再次运行就不会报错了
参考文章:
https://blog.csdn.net/weixin_43042683/article/details/106779060
https://www.cnblogs.com/jing-tian/p/11688073.html
到此这篇关于Nodejs 连接 mysql时报Error: Cannot enqueue Query after fatal error错误的处理办法的文章就介绍到这了,更多相关Nodejs 连接 mysql报错内容请搜索编程学习网以前的文章希望大家以后多多支持编程学习网!
本文标题为:Nodejs 连接 mysql时报Error: Cannot enqueue Query after fatal error错误的处理办法
基础教程推荐
- js禁止页面刷新与后退的方法 2024-01-08
- CSS3的几个标签速记(推荐) 2024-04-07
- 浅谈Vue2和Vue3的数据响应 2023-10-08
- 基于Vue制作组织架构树组件 2024-04-08
- JS前端广告拦截实现原理解析 2024-04-22
- vue离线环境如何安装脚手架vue-cli 2025-01-19
- Ajax实现动态加载数据 2023-02-01
- 关于文字内容过长,导致文本内容超出html 标签宽度的解决方法之自动换行 2023-10-28
- this[] 指的是什么内容 讨论 2023-11-30
- 浅析canvas元素的html尺寸和css尺寸对元素视觉的影响 2024-04-26
