ERROR 1045 (28000): Access denied for user'root'@'localhost'(using password: yes)
一. 在忘记root密码的时候
以windows为例:
1. 关闭正在运行的MySQL服务。计算机--管理
2. 打开DOS窗口,转到mysql\bin目录
3. 输入mysqld --skip-grant-tables 回车
--skip-grant-tables 的意思是启动MySQL服务的时候跳过权限表认证。
4. 再开一个DOS窗口(因为刚才那个DOS窗口已经不能动了),转到mysql\bin目录,mysql回车。
5. 连接权限数据库: use mysql; (别忘了最后加分号)
6. 改密码:update user set password=password(“123”) where user=“root”; (别忘了最后加分号)
如果修改密码出现(新版本mysql,没有password字段,改为authentication_string):
**mysql修改密码错误 ERROR 1054 (42S22)**,
则使用 mysql>update user set authentication_string=password("123456") where user="root";
7. mysql>flush privileges; 更新权限。
8. 退出 quit,输入 mysql -u root -p,使用新密码登录即可。
二. 知道root密码的时候
方法1: 用SET PASSWORD命令 首先登录MySQL。
格式:mysql> set password for 用户名@localhost = password('新密码');
例子:mysql> set password for root@localhost = password('123');
方法2:用mysqladmin 格式:mysqladmin -u用户名 -p旧密码 password 新密码
例子:mysqladmin -uroot -p123456 password 123
方法3:用UPDATE直接编辑user表 首先登录MySQL。
mysql> use mysql;
mysql> update user set password=password('123') where user='root' and host='localhost';
mysql> flush privileges;