mysql有时候忘记密码了怎么办?

我给出案例和说明!一下就解决了!

Windows下的实际操作如下

1.关闭正在运行的MySQL。

2.打开DOS窗口,转到mysqlbin目录。

3.输入mysqld --skip-grant-tables回车。如果没有出现提示信息,那就对了。

4.再开一个DOS窗口(因为刚才那个DOS窗口已经不能动了),转到mysqlbin目录。

5.输入mysql回车,如果成功,将出现MySQL提示符 >

6.连接权限数据库>use mysql; (>是本来就有的提示符,别忘了最后的分号)

6.改密码:> update user set password=password(520) where user=root; (别忘了最后的分号)

7.刷新权限(必须的步骤)>flush privileges;

8.退出 > q

9.注销系统,再进入,开MySQL,使用用户名root和刚才设置的新密码123456登陆。


Linux 下的实际操作如下

1. 关闭正在运行的Mysql
    $ /etc/init.d/mysqld stop
2. # vi /etc/my.cnf
    在[mysqld]的段中加上一句:skip-grant-tables
    例如:
    [mysqld]
    datadir=/var/lib/mysql
    socket=/var/lib/mysql/mysql.sock
    skip-grant-tables 
3. 重新启动mysqld
    $ /etc/init.d/mysqld restart 
4. 登录并修改MySQL的root密码 
    $ mysql
5. 修改密码
    mysql> UPDATE user SET Password = password ( 'new-password' ) WHERE User = 'root' ;
    Query OK, 0 rows affected (0.00 sec)
    Rows matched: 2 Changed: 0 Warnings: 0
    mysql> flush privileges ;
    Query OK, 0 rows affected (0.01 sec)
    mysql> quit
    Bye 
6. 将MySQL的登录设置修改回来
    # vi /etc/my.cnf
    将刚才在[mysqld]的段中加上的skip-grant-tables删除
    保存并且退出vi。
7. 重新启动mysqld
    # /etc/init.d/mysqld restart
    Stopping MySQL: [ OK ]
    Starting MySQL: [ OK ]