该错误的原因是在MySQL8之前版本中加密规则是mysql_native_password,而在MySQL8以后的加密规则为caching_sha2_password。

解决此问题有两种方法,一种是更新navicat驱动来解决此问题,一种是将mysql用户登录的加密规则修改为mysql_native_password。此处采用第二种方式。

具体做法:

1.使用cmd的方式连接到MySQL数据库

2.设置密码永不过期

alter user 'root'@'localhost' identified by '密码' password expire never;

3.设置加密规则为mysql_native_password

alter user 'root'@'localhost' identified with mysql_native_password by '密码';

4.重启Navicat 在进行连接测试

5.如果以上方法试了还不行 就继续执行下面的两条命令 操作同上

alter user 'root'@'%' identified by '密码' password expire never;alter user 'root'@'%' identified with mysql_native_password by'密码';

6. 如果都试了还不行 那在看看其他博主发的贴吧 希望可以帮到你

尾注:每一行代码 都是改变世界的能量 愿你每一次的运行 都是发自内心的快乐