原帖地址: http://topic.csdn.net/u/20090515/21/2b3c9a12-d8a5-4bb1-9895-6069cef5aef8.html

方法一: 
# /etc/init.d/mysql stop 
# mysqld_safe --user=mysql --skip-grant-tables --skip-networking & 
# mysql -u root mysql 
mysql> UPDATE user SET Password=PASSWORD(’newpassword’) where USER=’root’; 
mysql> FLUSH PRIVILEGES; 
mysql> quit 
# /etc/init.d/mysql restart 
# mysql -uroot -p 
Enter password: <输入新设的密码newpassword> 
mysql> 
方法二: 
直接使用/etc/mysql/debian.cnf文件中[client]节提供的用户名和密码: 
# mysql -udebian-sys-maint -p 
Enter password: <输入[client]节的密码> 
mysql> UPDATE user SET Password=PASSWORD(’newpassword’) where USER=’root’; 
mysql> FLUSH PRIVILEGES; 
mysql> quit 
# mysql -uroot -p 
Enter password: <输入新设的密码newpassword> 
mysql> 

内容来自: 脚本之家 www.jb51.net 

另一个方法
Windows:

1. 管理员登陆系统,停止mysql服务或者结束mysqld-nt进程
2. 进入命令行,来到mysql的安装目录.假设安装目录为 d:\mysql\ , CMD进入命令行
3. 运行 d:\mysql\bin\mysqld-nt --skip-grant-tables 启动mysql,关闭权限的检查
4. 运行 d:\mysql\bin\mysqladmin -u root flush-privileges password "newpassword" 重设root密码
5. 重新启动mysql服务

 

note:1.我的mysql装在e:/AppServ/下,故e:/AppServ/bin/mysqld-nt --skip-grant-tables

  2.使用mysqld-nt ,如果提示指令不存在,可是尝试换成mysqld, 或者mysql_safe

 3 但是,貌似第三步没有成功,进行第四步时提示:‘access denied for user  root@localhost ’,不是跳过权限吗?怎么还要权限?~~

因此,实际上,我用上面方法没成功~~~

无奈之际,竟然发现mysql自带了修改密码的小工具:‘reset mysql root password’ !!
无语。。。
好在可以随心所欲改密码了。。

可是上面为什么‘关闭权限检查’后还要权限呢?~~