最近在学习django的时候需要用到数据库,于是便下载了navicat准备和mysql配套使用,但是在连接的时候确出现了如下问题:

navicat连接mysql出现2059错误 Mysql 第1张

SRE实战 互联网时代守护先锋,助力企业售后服务体系运筹帷幄!一键直达领取阿里云限量特价优惠。

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

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

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

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

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

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

-正常情况下继续使用navicat连接mysql即可成功,但是,本人却死在了第一步,无法进入数据库;

navicat连接mysql出现2059错误 Mysql 第2张

-不知道有没有和我一样的小伙伴遇到这种情况,但是不要慌,cmd不让进,我们可以直接用mysql client登录呀;

-输入密码,进入mysql,输入第二点中的命令即可解决。

navicat连接mysql出现2059错误 Mysql 第3张

 

扫码关注我们
微信号:SRE实战
拒绝背锅 运筹帷幄