重置 MySQL root 密码的核心步骤是绕过权限验证登录数据库并更新密码字段。以下是具体方法:
方法一:通过 --SKIP-GRANT-TABLES
模式修改密码
-
停止 MySQL 服务
-
以跳过权限验证模式启动 MySQL
- 打开命令行(Windows)或终端(Linux),输入:
Bash
mysqld --skip-grant-tables --shared-memory
- 此时 MySQL 会忽略权限验证,允许无密码登录。
- 打开命令行(Windows)或终端(Linux),输入:
-
登录并修改密码
-
重启 MySQL 服务
方法二:使用 --INIT-FILE
参数(推荐用于生产环境)
-
创建密码修改脚本
- 新建文件
reset_password.sql
,内容为:Sql
ALTER USER 'root'@'localhost' IDENTIFIED BY '新密码';
- 新建文件
-
停止 MySQL 服务(同上)。
-
启动 MySQL 并指定初始化文件
Bash
mysqld --init-file=/path/to/reset_password.sql
- 服务启动后会自动执行脚本更新密码1。
-
重启服务正常模式。