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 '新密码';
相关推荐
lkforce4 小时前
mysql表连接,因类型不匹配而导致索引失效的场景
数据库·mysql
普通网友4 小时前
【mysql】锁机制 - 2.行锁间隙锁临键锁
数据库·mysql
zwtahql4 小时前
mysql的安装和卸载过程
数据库·mysql
Siren_dream4 小时前
在Ubuntu通过命令行安装MySQL(tabby远程)
mysql·ubuntu
零起飞4 小时前
生产管理系统详解:高离散制造 – 生产订单数据库设计表(核心表结构)
数据库·oracle·制造
李慕婉学姐4 小时前
Springboot旅游管理系统8cx8xy5m(程序+源码+数据库+调试部署+开发环境)带论文文档1万字以上,文末可获取,系统界面在最后面。
数据库·spring boot·旅游
国服第二切图仔5 小时前
Rust开发之使用anyhow与thiserror简化错误处理
服务器·数据库·rust
金仓拾光集5 小时前
金仓替代MongoDB:互联网医院聊天脱敏实战
数据库·mongodb·kingbase·kingbasees·数据库平替用金仓·金仓数据库
rexling15 小时前
【MySQL】mysqldump使用方法
数据库·mysql·adb