mysql修改密码

本文整理了不同场景下 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 法(推荐,更安全)
  1. 创建初始化文件:新建 C:\mysql-init.txt,写入:

    复制代码
    ALTER USER 'root'@'localhost' IDENTIFIED BY '你的新密码';
  2. 停止 MySQL 服务:

    复制代码
    net stop mysql
    # 若失效,尝试:sc stop mysql
  3. 安全模式启动并执行文件(替换 my.ini 实际路径):

    复制代码
    mysqld --defaults-file="C:\ProgramData\MySQL\MySQL Server 8.0\my.ini" --init-file="C:\mysql-init.txt" --console
  4. 重启正常服务:

    复制代码
    net start mysql
方法 B:--skip-grant-tables 法(应急)
  1. 停止 MySQL 服务:net stop mysql

  2. 新建 reset.bat 批处理文件,内容:

    复制代码
    @echo off
    mysqld --skip-grant-tables --shared-memory --console
  3. 以管理员身份运行 reset.bat,保持窗口开启;

  4. 新开管理员命令行,无密码登录:mysql -u root

  5. 执行重置命令(按版本选择):

    复制代码
    -- 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;
  6. 关闭 reset.bat 窗口,重启 MySQL 服务:net start mysql

2. Linux/macOS 系统

方法 A:--skip-grant-tables 法(通用)
  1. 停止 MySQL 服务:

    复制代码
    sudo systemctl stop mysql
    # 或:sudo service mysql stop
  2. 安全模式启动:

    复制代码
    sudo mysqld_safe --skip-grant-tables --skip-networking &
  3. 无密码登录:mysql -u root

  4. 执行重置命令(按版本选择):

    复制代码
    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;
  5. 重启服务: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 '你的新密码';

五、修改后验证

  1. 测试新密码登录:

    复制代码
    mysql -u root -p
    # 输入新密码,能登录则生效
  2. 查看用户密码信息:

    复制代码
    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

重要提醒

  1. 密码修改后立即测试,避免登录失败;
  2. 生产环境务必使用强密码(数字 + 字母 + 特殊符号);
  3. 修改前建议备份数据库,防止操作失误;
  4. 远程连接需修改 'root'@'%' 密码,而非仅 'root'@'localhost'
相关推荐
天下·第二12 小时前
达梦数据库适配
android·数据库·adb
感谢地心引力15 小时前
【Android】Shizuku 加 SystemUI Tuner 实现手机状态栏特定图标隐藏(小米 Hyper OS 3为例)
android·adb·智能手机·调试·hyper os·shizuku
搬砖的工人1 天前
记录一次windows 安装 mysq过程
android·windows·adb
_F_y2 天前
MySQL用户管理
android·mysql·adb
定偶2 天前
C语言操作MYSQL
c语言·mysql·adb
一池秋_2 天前
aarch64_Ubuntu (Linux)连不上adb解决方法
linux·ubuntu·adb
深念Y2 天前
中兴微随身WiFi 板号UZ901_v1.6 影腾Y1新版本 增加SIM卡槽 开启ADB 去云控 改串号教程 下
数据库·adb
yantaohk2 天前
【2025亲测】中兴B860AV3.2M完美刷机包ATV版本安卓9-解决1G运存BUG,开ADB已ROOT
android·嵌入式硬件·adb·云计算
远方之巅2 天前
ADB调试工具与GLM-4.6V-Flash-WEB移动端集成实战
adb· glm-4.6v-flash-web· 多模态模型
爱技术的小伙子3 天前
【 Docker 快速部署 MySQL 8.0(2026最新实践)—— 一键启动 + 数据持久化 + 常见优化】
mysql·adb·docker