如何重置 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;

相关推荐
isNotNullX7 分钟前
数据处理的流程是什么?如何进行数据预处理?
数据库·数据资产管理·数据处理·企业数字化
TAEHENGV10 分钟前
基本设置模块 Cordova 与 OpenHarmony 混合开发实战
android·java·数据库
Leo18714 分钟前
MySQL 回表(Back to Table)详解
数据库·mysql
遇见火星18 分钟前
MySQL 8.0复制架构主从自动切换脚本
mysql·adb·架构·mysql8.0·mysql主从
不知江月待何人..18 分钟前
MySQL服务无法启动问题
数据库·mysql
廋到被风吹走24 分钟前
【数据库】【Oracle】SQL基础
数据库·sql·oracle
曹牧44 分钟前
Oracle统计每日发生次数
数据库·oracle
范纹杉想快点毕业1 小时前
返璞归真还是拥抱现代?——嵌入式研发中的“裸机开发”与RTOS全景解析
c语言·数据库·mongodb·设计模式·nosql
辗转.9531 小时前
MongoDB入门指南:从零开始掌握NoSQL数据库
数据库·mongodb·nosql
有什么东东1 小时前
山东大学软件学院2024-2025非关系型数据库背诵整理
数据库·nosql