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. 进入后是这样的:
    image

  4. 输入MySQL语句

    先输入alter user 'root'@'localhost' identified with mysql_native_password by '123456';

    出现:
    image

    再输入flush privileges;

    出现:
    image

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

参考文章:

原文参考链接1:https://blog.csdn.net/weixin_43042683/article/details/106779060
原文参考链接2:https://www.cnblogs.com/jing-tian/p/11688073.html

posted @ 2021-11-13 16:11  Yunjiang  阅读(1559)  评论(0编辑  收藏  举报