Navicat连接数据库MySQL报错2059

  1. 解释原因:据说,mysql8 之前的版本中加密规则是mysql_native_password,而在mysql8之后,加密规则是caching_sha2_password, 解决问题方法有两种,一种是升级navicat驱动,一种是把mysql用户登录密码加密规则还原成mysql_native_password. 现在说第二种方式 
  2. 命令行进入MySQL数据库
  3. 输入以下指令,逐行输入,每行后加一个回车
  4. ALTER USER 'root'@'localhost' IDENTIFIED BY 'password' PASSWORD EXPIRE NEVER; #修改加密规则 
    ALTER USER 'root'@'localhost' IDENTIFIED WITH mysql_native_password BY 'password'; #更新一下用户的密码 
    FLUSH PRIVILEGES; #刷新权限 
    就像这样

Navicat连接数据库MySQL报错2059_第1张图片

5.然后按理说应该是可以了,祝君好运。

6.Tips:命令行中用的“password”即为更新后的数据库密码,可改为自己想设置的密码,比如“123”什么的,之后再用Navicat连接MySQL就连接成功了,亲测可用!!!

你可能感兴趣的:(JavaWeb/JavaEE)