忘记MySQL数据库的root密码时如何重置密码
提示: 这是一篇由阿里云ACE开发者(Alibaba Cloud Engineer)贡献,针对特定用户问题发布的文章。文档的内容以原稿呈现,阿里云对于文档内容不做任何形式的承诺。阿里云有权在未经通知的情形下对文档内容做出任何形式的修改。
概述
本文主要介绍忘记MySQL数据库的root密码时如何重置密码。
详细信息
修改Linux系统中MySQL数据库的root密码
如果忘记了MySQL数据库root用户的密码,可以通过修改配置文件,登录时跳过密码,然后在数据库里面修改密码。一般数据库默认的用户为root。
- 执行如下命令,编辑MySQL数据库的my.cnf配置文件。
vim /etc/my.cnf
注:my.cnf配置文件的路径以实际环境为准。
- 在[mysqld]字段下新增如下内容,然后保存退出。
skip-grant-tables
- 执行如下命令,重启MySQL服务。
/etc/init.d/mysqld restart
注:MySQL启动脚本路径以实际环境为准。
- 执行如下命令,登录数据库。
/usr/bin/mysql
注:MySQL命令路径以实际环境为准。
- 依次执行如下SQL语句,更新密码。
USE mysql;
UPDATE user SET Password = password ('[$Password]') WHERE User = 'root';
flush privileges;
quit注:[$Password]为新密码,不建议新密码为“123456”,此密码太简单,密码需要满足密码复杂性要求,需要大小写字母和数字组合,最小长度为8位,根据此密码策略,设置密码。
- 再次编辑
/etc/my.cnf
配置文件,删除或者注释第2步添加的skip-grant-tables。 - 执行如下命令,重启MySQL服务。
/etc/init.d/mysqld restart
- 使用新密码登录数据库,确认能正常登录。
修改Windows系统中MySQL数据库的root密码
本文的操作系统以“Windows Server 2008 R2 标准版 SP1 64位中文版”为例,MySQL版本以”mysql Ver 14.12 Distrib 5.0.87, for Win32 (ia32)”为例,其他版本的操作方法类型。
- 登录终端,切换至MySQL的bin目录。
提示:MySQL服务的bin目录以实际环境为准。
- 执行如下命令,停止MySQL服务。
net stop mysql
- 执行如下命令,以安全模式启动MySQL服务。
mysqld-nt.exe --skip-grant-tables
-
登录另一个终端,执行如下命令,登录MySQL数据库。
mysql -uroot -p
- 依次执行如下SQL语句,更新密码,完成后退出。
use mysql;
update user SET Password = password ('[$Password]') where User = 'root';
flush privileges;
exit - 打开任务管理器,关闭mysql相关进程。
- 执行如下命令,启动MySQL服务。
net start mysql
- 执行如下命令,使用新密码登录数据库。确认能正常登录数据库说明修改成功。
mysql -uroot -p[$Password]
适用于
- 云服务器 ECS