mysql重置密码

出现 "ERROR 1045 (28000): Access denied for user 'root'@'localhost' (using password: YES)",说明输入的密码与root用户的密码不匹配,或密码重置修改未生效。

完整重置密步骤(Windows + MySQL 8.0)

1. 彻底停止 MySQL 服务
  • Win + R → 输入 services.msc → 找到 MySQL 服务 → 右键 "停止"(确保状态为 "已停止")。
2. 以 "跳过权限" 模式启动 MySQL
  • 打开 管理员命令提示符 (必须管理员身份!),进入bin目录:

    cmd

    复制代码
    cd C:\Program Files\MySQL\MySQL Server 8.0\bin
  • 执行启动命令(保持此窗口开启,不要关闭): cmd

    复制代码
    mysqld --console --skip-grant-tables --shared-memory

    等待显示 ready for connections 再进行下一步。

3. 无密码登录 MySQL
  • 新开一个 管理员命令提示符 ,同样进入bin目录:

    cmd

    复制代码
    cd C:\Program Files\MySQL\MySQL Server 8.0\bin
  • 登录(直接回车,无需密码): cmd

    复制代码
    mysql -u root

    成功后会显示 mysql> 提示符。

4. 强制重置密码(关键步骤)

mysql> 下执行以下命令(逐行执行 ,替换'新密码'为你要设置的密码,比如'123456'):

sql

复制代码
-- 1. 刷新权限(必须先执行)
FLUSH PRIVILEGES;

-- 2. 强制修改root密码(覆盖旧密码)
ALTER USER 'root'@'localhost' IDENTIFIED WITH mysql_native_password BY '新密码';

-- 3. 再次刷新权限(确保生效)
FLUSH PRIVILEGES;

若执行成功,会显示 Query OK, 0 rows affected

5. 重启 MySQL 服务
  • 关闭所有命令提示符窗口(包括运行 MySQL 服务的窗口)。
  • 回到 "服务" 窗口 → 启动 MySQL 服务。
6. 验证登录
  • 打开新的命令提示符(无需管理员),进入bin目录:

    cmd

    复制代码
    cd C:\Program Files\MySQL\MySQL Server 8.0\bin
  • 登录(输入你刚设置的新密码):

    cmd

    复制代码
    mysql -u root -p

如果仍失败,检查这 2 点:

  1. 密码是否包含特殊字符 :若密码有@、#、$等,输入时确保没有误按,或暂时用纯数字 / 字母测试(比如123456)。

  2. 用户主机是否匹配 :若之前的root用户允许远程连接(主机是%),需将步骤 4 的命令改为:

    sql

    复制代码
    ALTER USER 'root'@'%' IDENTIFIED WITH mysql_native_password BY '新密码';
相关推荐
萧曵 丶13 分钟前
MySQL三大日志系统浅谈
数据库·sql·mysql
煎蛋学姐18 分钟前
SSM校园兼职招聘系统x6u36(程序+源码+数据库+调试部署+开发环境)带论文文档1万字以上,文末可获取,系统界面在最后面
数据库·企业管理·ssm 框架·校园兼职招聘系统
ChineHe1 小时前
Redis基础篇004_Redis Pipeline流水线详解
数据库·redis·缓存
西柚补习生2 小时前
通用 PWM 原理基础教学
数据库·mongodb
小张程序人生2 小时前
ShardingJDBC读写分离详解与实战
数据库
木风小助理2 小时前
三大删除命令:MySQL 核心用法解析
数据库·oracle
tc&2 小时前
redis_cmd 内置防注入功能的原理与验证
数据库·redis·bootstrap
麦聪聊数据2 小时前
MySQL 性能调优:从EXPLAIN到JSON索引优化
数据库·sql·mysql·安全·json
Facechat2 小时前
视频混剪-时间轴设计
java·数据库·缓存
lalala_lulu3 小时前
MySQL中InnoDB支持的四种事务隔离级别名称,以及逐级之间的区别?(超详细版)
数据库·mysql