Navicat连接数据库错误--2059

解决Navicat连接数据库错误--2059

Navicat连接数据库错误--2059

数据库版本 ——8.0.18 (select version()
原因:
mysql8之前的版本的加密规则是mysql_native_password,在mysql8之后,加密规则变成了caching_sha2_password
解决方案:
#更改加密规则
mysql -uroot -ppassword #登录
#选择mysql库
use mysql;
#远程连接将'localhost'换成'%'
#更改加密方式
ALTER USER 'root'@'localhost' IDENTIFIED BY 'password' PASSWORD EXPIRE NEVER; 
#更新用户密码
ALTER USER 'root'@'localhost' IDENTIFIED WITH mysql_native_password BY 'password'; 
#刷新权限
FLUSH PRIVILEGES; 
mysql 如何修改root密码
一、用set password命令
  • eg: mysql> set password for 用户名@localhost = password('新密码');
  • mysql8:ALTER USER 'root'@'%' IDENTIFIED WITH mysql_native_password BY'password';
二、用mysqladmin
  • eg:mysqladmin -u用户名 -p旧密码 password 新密码 ;
三、直接update mysql库中的User表
  • mysql> use mysql; update user set password=password('123') where user='root' and host='localhost';
  • flush privileges;
四、忘记root密码时
以windows为例:
1. 关闭正在运行的MySQL服务。 
2. 打开DOS窗口,转到mysql\bin目录。 
3. 输入mysqld --skip-grant-tables//--skip-grant-tables 的意思是启动MySQL服务的时候跳过权限表认证。 
4. 再开一个DOS窗口(因为刚才那个DOS窗口已经不能动了),转到mysql\bin目录。 
5. 输入mysql回车,如果成功,将出现MySQL提示符 >。 
6. 连接权限数据库: use mysql; 。 
7. 改密码:update user set password=password("123") where user="root";(别忘了最后加分号) 。 
8. 刷新权限(必须步骤):flush privileges; 。 
9. 退出 quit。 
10. 注销系统,再进入,使用用户名root和刚才设置的新密码123登录。
上一篇:navicat连接mysql出现2059错误的解决方法


下一篇:navicat连接mysql出现2059错误的解决方法