Mysql 连接出现2059错误

最近在学习于是便下载了navicat准备和mysql8配套使用,但是在连接的时候确出现了如下问题:

网上查询过后,发现这个错误出现的原因是在mysql8之前的版本中加密规则为mysql_native_password,而在mysql8以后的加密规则为caching_sha2_password。

解决此问题有两种方法,一种是更新navicat驱动来解决此问题,一种是将mysql用户登录的加密规则修改为mysql_native_password。;根据网上大部分建议采取了第二种方式:

1.用管理员权限打开cmd,输入mysql -u root -p进入输入密码后进入mysql数据库;

1

mysql -u root -p #进入数据库

2.修改加密规则及密码,刷新即可;

 如果是远程链接需要将 localhost 替换成 % 进行输出命令。

use mysql; # 进入数据库

ALTER USER 'root'@'localhost' IDENTIFIED BY 'mysql密码' PASSWORD EXPIRE NEVER; #修改加密规则
ALTER USER 'root'@'localhost' IDENTIFIED WITH mysql_native_password BY 'mysql密码'; #修改密码
FLUSH PRIVILEGES; #刷新数据

修改完,就可以连接成功了。

进去之后可以进mysql数据库修改user表中的加密方式字段。

发布了47 篇原创文章 · 获赞 16 · 访问量 2万+

猜你喜欢

转载自blog.csdn.net/oschina_40730821/article/details/101097596