本文整理了不同场景下 MySQL 密码修改的方法,涵盖「记得密码」「忘记密码」「修改其他用户密码」及「MySQL 8.0+ 特殊处理」,适配 Windows/Linux/macOS 系统。
一、记得当前密码(正常登录修改)
适用于能正常登录 MySQL,仅需更换密码的场景,推荐优先使用 ALTER USER 命令。
1. MySQL 命令行修改
| 命令类型 | 适用版本 | 执行语句 |
|---|---|---|
| ALTER USER(推荐) | MySQL 5.7.6+ | ALTER USER 'root'@'localhost' IDENTIFIED BY '你的新密码'; |
| SET PASSWORD | MySQL 5.7.5 及以下 | SET PASSWORD FOR 'root'@'localhost' = PASSWORD('你的新密码'); |
| SET PASSWORD | MySQL 8.0+ | SET PASSWORD FOR 'root'@'localhost' = '你的新密码'; |
| UPDATE(不推荐) | 所有版本 | UPDATE mysql.user SET authentication_string = PASSWORD('你的新密码') WHERE User = 'root' AND Host = 'localhost'; FLUSH PRIVILEGES; |
2. mysqladmin 工具修改(命令行)
mysqladmin -u root -p password "你的新密码"
# 执行后会提示输入当前密码,验证通过后修改
二、忘记密码(重置 root 密码)
适用于无法登录 MySQL,需强制重置 root 密码的场景,分系统适配不同方法。
1. Windows 系统
方法 A:--init-file 法(推荐,更安全)
-
创建初始化文件:新建
C:\mysql-init.txt,写入:ALTER USER 'root'@'localhost' IDENTIFIED BY '你的新密码'; -
停止 MySQL 服务:
net stop mysql # 若失效,尝试:sc stop mysql -
安全模式启动并执行文件(替换 my.ini 实际路径):
mysqld --defaults-file="C:\ProgramData\MySQL\MySQL Server 8.0\my.ini" --init-file="C:\mysql-init.txt" --console -
重启正常服务:
net start mysql
方法 B:--skip-grant-tables 法(应急)
-
停止 MySQL 服务:
net stop mysql -
新建
reset.bat批处理文件,内容:@echo off mysqld --skip-grant-tables --shared-memory --console -
以管理员身份运行
reset.bat,保持窗口开启; -
新开管理员命令行,无密码登录:
mysql -u root -
执行重置命令(按版本选择):
-- MySQL 5.7.6+ ALTER USER 'root'@'localhost' IDENTIFIED BY '你的新密码'; -- MySQL 5.7.5 及以下 UPDATE mysql.user SET authentication_string = PASSWORD('你的新密码') WHERE User = 'root' AND Host = 'localhost'; FLUSH PRIVILEGES; -
关闭
reset.bat窗口,重启 MySQL 服务:net start mysql
2. Linux/macOS 系统
方法 A:--skip-grant-tables 法(通用)
-
停止 MySQL 服务:
sudo systemctl stop mysql # 或:sudo service mysql stop -
安全模式启动:
sudo mysqld_safe --skip-grant-tables --skip-networking & -
无密码登录:
mysql -u root -
执行重置命令(按版本选择):
USE mysql; -- MySQL 8.0+ ALTER USER 'root'@'localhost' IDENTIFIED BY '你的新密码'; -- MySQL 5.7 UPDATE user SET authentication_string = PASSWORD('你的新密码') WHERE User = 'root'; FLUSH PRIVILEGES; EXIT; -
重启服务:
sudo systemctl restart mysql
方法 B:debian-sys-maint 法(Debian/Ubuntu 专属)
# 1. 查看系统自动生成的管理密码
sudo cat /etc/mysql/debian.cnf
# 2. 使用该密码登录 MySQL
mysql -u debian-sys-maint -p
# 3. 修改 root 密码
ALTER USER 'root'@'localhost' IDENTIFIED BY '你的新密码';
三、修改其他用户密码
适用于修改非 root 用户的密码,格式统一,仅需替换用户名 / 主机名:
-- 通用格式
ALTER USER '用户名'@'主机名' IDENTIFIED BY '新密码';
-- 示例1:修改 admin 用户(允许所有主机访问)
ALTER USER 'admin'@'%' IDENTIFIED BY 'new_password123';
-- 示例2:修改 test 用户(仅本地访问)
ALTER USER 'test'@'localhost' IDENTIFIED BY 'testpass';
四、MySQL 8.0+ 特殊注意事项
1. 密码策略限制(无法设置简单密码)
-- 1. 查看当前密码策略
SHOW VARIABLES LIKE 'validate_password%';
-- 2. 临时降低策略强度(测试环境,重启失效)
SET GLOBAL validate_password.policy = LOW;
SET GLOBAL validate_password.length = 4;
-- 3. 再修改密码(示例:设置简单密码 1234)
ALTER USER 'root'@'localhost' IDENTIFIED BY '1234';
2. 认证插件兼容问题(caching_sha2_password 错误)
MySQL 8.0 默认使用 caching_sha2_password 插件,老客户端可能兼容失败,需切换为旧版插件:
ALTER USER 'root'@'localhost' IDENTIFIED WITH mysql_native_password BY '你的新密码';
五、修改后验证
-
测试新密码登录:
mysql -u root -p # 输入新密码,能登录则生效 -
查看用户密码信息:
SELECT user, host, authentication_string FROM mysql.user;
六、快速选择指南
| 场景 | 推荐方法 |
|---|---|
| 记得当前密码 | 使用 ALTER USER 命令 |
| 忘记 root 密码(Windows) | --init-file 法 |
| 忘记 root 密码(Linux/macOS) | --skip-grant-tables 法 |
| MySQL 8.0+ 设置简单密码 | 先降低密码策略,再修改密码 |
| 老客户端连接 MySQL 8.0+ | 修改认证插件为 mysql_native_password |
重要提醒
- 密码修改后立即测试,避免登录失败;
- 生产环境务必使用强密码(数字 + 字母 + 特殊符号);
- 修改前建议备份数据库,防止操作失误;
- 远程连接需修改
'root'@'%'密码,而非仅'root'@'localhost'。