mysql5.7忘记密码时,修改root密码

(1)由于MySQL5.7在安装完后,第一次启动时,会在root目录下生产一个随机的密码,文件名 mysql_secret 

所以,登录时需要用随机密码登录,然后通过以下命令修改密码 “SET PASSWORD = PASSWORD(‘new password’);”

2). 在忘记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 mysql.user set authentication_string=password('123456') where user='root' and Host ='localhost';

或者 update MySQL.user set password=PASSWORD(‘123456’) where User=’root’;

    8. mysql>flush privileges;   #更新权限

    9. 退出 quit。 

    10. 注销系统,再进入,

    输入 mysql -u root -p

    使用用户名root和刚才设置的新密码123456登录。 

(3). 知道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; 

猜你喜欢

转载自wm920.iteye.com/blog/2379612