转自:http://www.jb51.net/article/39454.htm
方法1: 用SET PASSWORD命令
首先登录MySQL。
格式:mysql> set password for 用户名@localhost = password('新密码');
例子:mysql> set password for root@localhost = password('123');
方法2:用mysqladmin
格式:mysqladmin -u用户名 -p旧密码 password 新密码
例子:mysqladmin -uroot -p123456 password 123
方法3:用UPDATE直接编辑user表
首先登录MySQL。
mysql> use mysql;
mysql> update user set password=password('123') where user='root' and host='localhost';
mysql> flush privileges;
方法4:在忘记root密码的时候,可以这样
以windows为例:
1. 关闭正在运行的MySQL服务。
2.编辑my.cnf(linux) /my.ini(windows)
3. 搜索mysqld 添加 skip-grant-tables ,重启 service mysqld restart。skip-grant-tables 的意思是启动MySQL服务的时候跳过权限表认证。
4. 输入mysql回车,如果成功,将出现MySQL提示符 >。
5. 连接权限数据库: use mysql; 。
6. 改密码:update user set authentication_string=password("123") where user="root";(别忘了最后加分号) 。
5.7版本会有安 全策略限制默认密码8位,修改为最少4位 :set global validate_password_length=1;
7. 刷新权限(必须步骤):flush privileges; 。
8. 退出 exit,去掉my.cnf中的skip配置
9. 重启mysql再进入,使用用户名root和刚才设置的新密码123登录。