Mysql忘记密码解决方案

来源:互联网 发布:阿瓦隆b族洗发水 知乎 编辑:程序博客网 时间:2024/05/17 19:21

一、Windows系统:

1、停止MYSQL服务,CMD打开DOS窗口,输入 net stop mysql
2、在CMD命令行窗口,进入MYSQL安装目录 比如D:\Program Files\mysql-advanced-5.6.25-winx64\bin
示范命令:
输入 D:回车,
输入cd "D:\Program Files\mysql-advanced-5.6.25-winx64\bin"
这样就可以进入Mysql安装目录了.
3、进入mysql安全模式,即当mysql起来后,不用输入密码就能进入数据库。
命令为: mysqld-nt --skip-grant-tables
4、重新打开一个CMD命令行窗口,输入mysql -uroot -p,使用空密码的方式登录MySQL(不用输入密码,直接按回车)
5、输入以下命令开始修改root用户的密码(注意:命令中mysql.user中间有个“点”)
mysql> update mysql.user set password=PASSWORD('新密码') where User='root';
6、刷新权限表
mysql> flush privileges;
7、退出
mysql> quit
MYSQL超级管理员账号root已经重新设置好了,接下来 在任务管理器里结束掉 mysql.exe 这个进程,重新启动MYSQL即可!(也可以直接重新启动服务器)
MYSQL重新启动后,就可以用新设置的root密码登陆MYSQL了!

二、Linux系统:

1、修改MySQL的登录设置:

# vi /etc/my.cnf

在[mysqld]的段中加上一句:skip-grant-tables
例如:
[mysqld]
datadir=/var/lib/mysql
socket=/var/lib/mysql/mysql.sock
skip-grant-tables
保存并且退出vi。

2、重新启动mysqld

# /etc/init.d/mysqld restart

3、登录并修改MySQL的root密码

# /usr/bin/mysql

......Type 'help;' or '\h' for help. Type '\c' to clear the buffer.

mysql>use mysql ;

......Database changed

mysql>update user set password = password ( 'new-password' ) where  user = 'root' ;

......Rows matched: 2 Changed: 0 Warnings: 0

mysql> flush privileges ;

......Query OK, 0 rows affected (0.01 sec)

mysql> quit
......Bye

5.将MySQL的登录设置修改回来

# vi /etc/my.cnf

将刚才在[mysqld]的段中加上的skip-grant-tables删除
保存并且退出vi。

6.重新启动mysqld
# /etc/init.d/mysqld restart

0 0
原创粉丝点击