1>停止mysql.
# /etc/init.d/mysqld stop
2>修改MySQL的登录设置
# vi /etc/my.cnf
在[mysqld]的段中加上一句:skip-grant-tables
例如:
[mysqld]
port = 3306
socket = /tmp/mysql.sock
skip-external-locking
skip-grant-tables
保存并且退出vi。
3>重新启动mysql
# /etc/init.d/mysqld restart
4>登录并修改mysql的root密码
# /usr/bin/mysql
mysql> USE mysql ;
mysql> UPDATE user SET Password = password('newpassword') WHERE User = 'root' ;
mysql> flush privileges ;
mysql> quit ;//www.111cn.net
5>将mysql的登录设置修改回来
# vi /etc/my.cnf
将刚才在[mysqld]的段中加上的skip-grant-tables删除
保存并且退出vi。
6>重新启动mysql
# /etc/init.d/mysqld restart
例子,一个万能的方法
作为可选方式,在任何平台上,可使用mysql客户端设置新密码(但该方法不够安全):
停止mysqld,并用“–skip-grant-tables –user=root”选项重启它(Windows用户可省略–user=root部分)。
使用下述命令连接到mysqld服务器:www.111Cn.net
shell> mysql -u root
在mysql客户端发出下述语句:
mysql> UPDATE mysql.user SET Password=PASSWORD(‘newpwd’)
-> WHERE User=’root’;
mysql> FLUSH PRIVILEGES;
用打算使用的实际根用户密码替换“newpwd”。
应能使用新密码进行连接。