如题,在用Navicat连接本地数据库的时候出现了这个问题。
上网查到了解决方案,记录总结一下

问题原因
加密规则变化
mysql8 之前的版本中加密规则是mysql_native_password,而在mysql8之后,加密规则是caching_sha2_password
解决方法
首先win+r打开命令行
然后连接本地数据库,进行更改规则
mysql -u root -p #登录
#输入密码
use mysql; #进入mysql数据库
ALTER USER 'root'@'localhost' IDENTIFIED BY 'password' PASSWORD EXPIRE NEVER; #更改加密方式
ALTER USER 'root'@'localhost' IDENTIFIED WITH mysql_native_password BY 'password'; #更新用户密码
FLUSH PRIVILEGES; #刷新权限
不要忘记把password替换成你自己的密码,还有不要忘记分号。。。
就像这样,

接下来就可以成功连接数据库了!

本文详细介绍了在使用Navicat连接MySQL 8.0时遇到的加密规则变化问题及解决方法。由于MySQL 8.0默认加密规则更改为caching_sha2_password,导致Navicat无法正常连接。通过修改加密方式为mysql_native_password并刷新权限,可恢复正常连接。
1723

被折叠的 条评论
为什么被折叠?



