如何重置 MySQL root 用户的登录密码?

重置 MySQL root 密码的核心步骤是绕过权限验证登录数据库更新密码字段。以下是具体方法:


方法一:通过 --SKIP-GRANT-TABLES 模式修改密码
  1. 停止 MySQL 服务

    • Windows :在命令行执行 net stop mysql(服务名可能为 mysql80mysql57,需根据实际名称调整)4 5
    • Linux :执行 sudo systemctl stop mysqlsudo service mysql stop
  2. 以跳过权限验证模式启动 MySQL

    • 打开命令行(Windows)或终端(Linux),输入:

      复制代码

      Bash

      mysqld --skip-grant-tables --shared-memory

    • 此时 MySQL 会忽略权限验证,允许无密码登录。

  3. 登录并修改密码

    • 新开一个命令行/终端窗口,输入:

      复制代码

      Bash

      mysql -u root

    • 执行以下 SQL 语句(注意版本差异):

      • MySQL 5.7 及以上

        复制代码

        Sql

        UPDATE mysql.user SET authentication_string=PASSWORD('新密码') WHERE User='root'; FLUSH PRIVILEGES;

      • MySQL 8.0 及以上

        复制代码

        Sql

        ALTER USER 'root'@'localhost' IDENTIFIED WITH mysql_native_password BY '新密码'; FLUSH PRIVILEGES;

      3 4

  4. 重启 MySQL 服务

    • 关闭所有 MySQL 进程,重新启动服务:

      复制代码

      Bash

      net start mysql # Windows sudo systemctl start mysql # Linux


方法二:使用 --INIT-FILE 参数(推荐用于生产环境)
  1. 创建密码修改脚本

    • 新建文件 reset_password.sql,内容为:

      复制代码

      Sql

      ALTER USER 'root'@'localhost' IDENTIFIED BY '新密码';

  2. 停止 MySQL 服务(同上)。

  3. 启动 MySQL 并指定初始化文件

    复制代码

    Bash

    mysqld --init-file=/path/to/reset_password.sql

    • 服务启动后会自动执行脚本更新密码1
  4. 重启服务正常模式


注意事项
  1. 如果出现 authentication_string 字段更新失败,尝试先置空密码再修改:

    复制代码

    Sql

    UPDATE mysql.user SET authentication_string='' WHERE User='root'; FLUSH PRIVILEGES;

  2. 修改完成后,检查 mysql.user 表确保权限生效:

    复制代码

    Sql

    SELECT user, host, authentication_string FROM mysql.user;

相关推荐
zhaoyong22236 分钟前
MySQL 存储过程中字符集与排序规则不匹配导致查询性能下降的解决方案
jvm·数据库·python
sinat_3834373637 分钟前
golang如何从Python转型Go开发_golang从Python转型Go开发攻略
jvm·数据库·python
远洪38 分钟前
claude code 国内安装使用
数据库·mysql
雨辰AI42 分钟前
SpringBoot3 + 人大金仓 V9 微服务监控实战|Prometheus+Grafana+SkyWalking 全链路监控
数据库·后端·微服务·grafana·prometheus·skywalking
二哈赛车手42 分钟前
新人笔记---ES和kibana启动问题以及一些常用的linux的错误排查方法,以及ES,数据库泄密解决方案[超详细]
java·linux·数据库·spring boot·笔记·elasticsearch
myrh pdmd44 分钟前
maven导入spring框架
数据库·spring·maven
爬山算法1 小时前
MongoDB(118)如何在升级过程中进行数据备份?
数据库·mongodb·oracle
千月落2 小时前
Redis数据迁移
数据库·redis·缓存
wangbing11253 小时前
MySQL 官方 GPG 密钥过期问题
数据库·mysql
PaperData3 小时前
2000-2023年地级市数字基础设施评价指标体系
大数据·网络·数据库·人工智能·数据分析·经管