如何解决Nodejs连接MySQL时出现Cannot enqueue Query after fatal error的错误?

2026-03-31 15:051阅读0评论SEO教程
  • 内容介绍
  • 文章标签
  • 相关推荐

本文共计682个文字,预计阅读时间需要3分钟。

如何解决Nodejs连接MySQL时出现Cannot enqueue Query after fatal error的错误?

目录 + Nodejs + 连接 mysql 时报 Error: Cannot enqueue Query after fatal error 的处理方法

一、Nodejs 连接 mysql?

二、Nodejs 连接 mysql 时报错 Error: Cannot enqueue Query after fatal error

1. 原配置参数 2. 新配置参数

目录
  • Nodejs 连接 mysql时报Error: Cannot enqueue Query after fatal error错误的处理办法
    • 一、nodejs连接mysql?
    • 二、Nodejs 连接 mysql时报错 Error: Cannot enqueue Query after fatal error
      • 1.原配置参数
      • 2.新配置参数
  • 补充:Node.js连接MySQL数据库报错
    • 解决方法:

    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参数就可以了

    如何解决Nodejs连接MySQL时出现Cannot enqueue Query after fatal error的错误?

    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;

    出现:

    问题解决了,再次运行就不会报错了

    参考文章:

    blog.csdn.net/weixin_43042683/article/details/106779060

    www.cnblogs.com/jing-tian/p/11688073.html

    到此这篇关于Nodejs连接mysql时报Error:CannotenqueueQueryafterfatalerror错误的处理办法的文章就介绍到这了,更多相关Nodejs连接mysql报错内容请搜索自由互联以前的文章或继续浏览下面的相关文章希望大家以后多多支持自由互联!

    本文共计682个文字,预计阅读时间需要3分钟。

    如何解决Nodejs连接MySQL时出现Cannot enqueue Query after fatal error的错误?

    目录 + Nodejs + 连接 mysql 时报 Error: Cannot enqueue Query after fatal error 的处理方法

    一、Nodejs 连接 mysql?

    二、Nodejs 连接 mysql 时报错 Error: Cannot enqueue Query after fatal error

    1. 原配置参数 2. 新配置参数

    目录
    • Nodejs 连接 mysql时报Error: Cannot enqueue Query after fatal error错误的处理办法
      • 一、nodejs连接mysql?
      • 二、Nodejs 连接 mysql时报错 Error: Cannot enqueue Query after fatal error
        • 1.原配置参数
        • 2.新配置参数
    • 补充:Node.js连接MySQL数据库报错
      • 解决方法:

      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参数就可以了

      如何解决Nodejs连接MySQL时出现Cannot enqueue Query after fatal error的错误?

      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;

      出现:

      问题解决了,再次运行就不会报错了

      参考文章:

      blog.csdn.net/weixin_43042683/article/details/106779060

      www.cnblogs.com/jing-tian/p/11688073.html

      到此这篇关于Nodejs连接mysql时报Error:CannotenqueueQueryafterfatalerror错误的处理办法的文章就介绍到这了,更多相关Nodejs连接mysql报错内容请搜索自由互联以前的文章或继续浏览下面的相关文章希望大家以后多多支持自由互联!