win7 第一次装 mysql-5.7.16-winx64 ,不知道root 密码,该如何处理?

转载请注明出处:http://blog.csdn.net/qq_26093511/article/details/52851811
ERROR 1045 (28000): Access denied for user'root'@'localhost'(using password: yes)
(1). 在忘记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”; (别忘了最后加分号) .
如果修改密码出现
**mysql修改密码错误 ERROR 1054 (42S22)**
则使用 mysql>update user set authentication_string=password("123456") where user="root";
8. mysql>flush privileges;   #更新权限
9. 退出 quit.
10. 注销系统,再进入,
输入 mysql -u root -p
使用用户名root和刚才设置的新密码123456登录。

(2). 知道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;
posted @ 2016-10-18 19:32  隔壁王叔叔a  阅读(275)  评论(0编辑  收藏  举报