MySQL5.7.31忘记密码的解决方案
Posted
tags:
篇首语:本文由小常识网(cha138.com)小编为大家整理,主要介绍了MySQL5.7.31忘记密码的解决方案相关的知识,希望对你有一定的参考价值。
1、跳过授权表(通用)
㈠ 跳过授权表重启数据库
① 关闭数据库
[root@node1 ~]# mysqladmin shutdown -p
Enter password:
② 跳过授权表启动
友情提示:启动过程可能会一波三折,冷静分析看报错,必能解决!
# /mysql_3306/bin/mysqld --defaults-file=/mysql_3306/my.cnf --skip-grant-tables --skip-networking=on --user=mysql &
㈡ 刷新授权表(重要)
# mysql -uroot -p
Enter password:什么都不要输入,直接回车即可
mysql> flush privileges;
Query OK, 0 rows affected (0.00 sec)
㈢ 修改密码
mysql> alter user root@localhost identified by 123;
Query OK, 0 rows affected (0.00 sec)
补充:如果未能成功,则使用以下语句修改密码
mysql> UPDATE mysql.user SET authentication_string = PASSWORD(MyNewPass) WHERE User = root AND Host = localhost;
mysql> FLUSH PRIVILEGES;
修改密码后,使用jobs + kill命令,停止正在运行的mysqld进程。然后使用service启动服务
# jobs
# kill %1
# service mysql_3306 start
mysql密码忘记解决方案
方法:在忘记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; 。
6. 改密码:update user set password=password("123") where user="root";(别忘了最后加分号) 。
7. 刷新权限(必须步骤):flush privileges; 。
8. 退出 quit。
9. 注销系统,再进入,使用用户名root和刚才设置的新密码123登录。
以上是关于MySQL5.7.31忘记密码的解决方案的主要内容,如果未能解决你的问题,请参考以下文章