解压版mysql8.x登录报错与密码重置

本文详细介绍了在忘记MySQL8.x root密码或遇到登录错误时,如何通过一系列步骤重置密码,包括停止服务、免密登录、更新用户认证字符串及设置新密码。

解压版 MySQL8.x更改root密码

适用情况:
1、忘记密码
2、登陆时报错:ERROR 1045 (28000): Access denied for user ‘root’@‘localhost’ (using password: YES)
解决思路:
重置密码:ALTER USER ‘root’@‘localhost’ IDENTIFIED BY ‘新密码’;
操作步骤:
1、win+r
2、cmd
在这里插入图片描述
3、键入:net stop 服务名;(大多为mysql,我自己的为mysql8),停止MySQL服务
4、键入:mysqld --console --skip-grant-tables --shared-memory;
成功后光标会一直闪烁
在这里插入图片描述
5、再打开一个cmd,键入:mysql -uroot -p 直接回车,免密登录
6、键入:use mysql;
update user set authentication_string=’’ where user=‘root’;
将密码置空。exit退出
在这里插入图片描述
7、关闭第一次打开的cmd,即光标闪烁的那个
8、第二次打开的cmd继续键入:net start 服务名;
9、键入:mysql -uroot -p 回车、回车;密码以置空。
键入:use mysql;
修改密码:ALTER USER ‘root’@‘localhost’ IDENTIFIED BY ‘新密码’;
exit退出,再次键入mysql -uroot -p 回车,输入刚才的新密码,成功!
在这里插入图片描述

实践出真知,不枉我一下午的努力!

<think> 嗯,用户现在遇到了在cmd中打开mysql输入密码后无法连接的问题。之前用户已经尝试过设置环境变量,但问题依然存在。需要结合用户提供的引用内容来分析解决方案。 用户引用的两个资料很有参考价值。第一个引用说明标准连接命令应该是"mysql -hlocalhost -uroot -p",并提到XAMPP默认无密码的情况。第二个引用则展示了my.ini配置文件的修改范例,特别注意到其中关于认证插件的设置。 考虑到用户已经排除了环境变量问题,现在需要排查其他常见原因。首先想到的是端口占用问题,3306端口可能被其他程序占用。然后是认证插件兼容性问题,MySQL 8.0默认使用caching_sha2_password插件,旧版客户端可能不支持。另外服务未运行和配置文件错误也是常见原因。 用户可能是开发人员或者系统管理员,正在本地搭建MySQL环境。从ta能提供详细的引用内容来看,应该具备一定的技术基础,但可能对MySQL的底层配置不太熟悉。ta现在应该比较着急,因为基础功能无法使用会影响后续工作。 解决方案需要分层次排列:从最简单的服务状态检查开始,逐步深入到配置文件修改。特别注意要提醒用户修改配置文件时的注意事项,比如备份原文件、管理员权限保存等。对于认证插件问题需要详细说明两种解决方案,因为这是MySQL 8.x版本的常见痛点。 最后要考虑到用户可能的后续问题,比如如何重置密码、如何完全重装等,所以额外准备了三方面补充知识。这样当用户遇到更深层次问题时可以快速响应。 </think> 以下是针对CMD中MySQL输入密码后连接报错的全面解决方案,按优先级排序: ### 🔧 一、核心排查步骤 1. **检查MySQL服务状态** ```bash net start mysql ``` 若服务未运行,需先启动服务(管理员权限运行CMD): ```bash sc start mysql ``` 2. **验证端口占用** MySQL默认端口3306可能被占用: ```bash netstat -ano | findstr :3306 ``` 若被占用,结束冲突进程或修改`my.ini`中的`port`值。 3. **确认认证插件兼容性(MySQL 8.0+常见问题)** **步骤:** 1. 用Navicat等工具连接MySQL 2. 执行: ```sql SELECT plugin FROM mysql.user WHERE user='root'; ``` 3. 若返回`caching_sha2_password`,需修改为旧版认证方式(需重启服务): ```sql ALTER USER 'root'@'localhost' IDENTIFIED WITH mysql_native_password BY '你的新密码'; ``` ### ⚙ 二、配置文件修复(关键) 1. **定位`my.ini`文件** 通常位于`C:\ProgramData\MySQL\MySQL Server X.X\`或MySQL安装目录 2. **添加/修改配置(参考引用[2])** ```ini [mysqld] default_authentication_plugin=mysql_native_password # 解决认证插件报错 port=3306 character-set-server=utf8 [client] default-character-set=utf8 ``` > ⚠️ 修改后必须重启MySQL服务:`net stop mysql` → `net start mysql` ### 🔐 三、密码问题处理 1. **强制跳过密码验证(紧急恢复)** 1. 停止服务:`net stop mysql` 2. 创建初始化文件`init.txt`: ```sql ALTER USER 'root'@'localhost' IDENTIFIED BY 'NewPassword'; ``` 3. 启动服务时加载: ```bash mysqld --init-file=C:\init.txt ``` ### 📌 四、其他关键措施 - **防火墙设置**:允许`mysqld.exe`通过防火墙 - **路径转义问题**:若密码含特殊字符`!@$`等,需用双引号包裹: ```bash mysql -u root -p"Your!Pass@" ``` - **备份配置文件**:修改`my.ini`前务必备份 ### 🔍 补充诊断命令 ```bash mysql --version # 验证客户端版本 mysqladmin -u root ping # 测试服务可达性 ``` > **典型报错解决方案**: > - `ERROR 1045 (28000)`:检查密码/插件兼容性 > - `Can't connect to MySQL server`:确认服务状态和端口 > - `Access denied`:尝试密码重置流程[^2] --- ### ❓相关问题 1. MySQL 8.0默认的`caching_sha2_password`插件为何导致旧客户端连接失败? 2. 如何永久修改MySQL的默认认证方式? 3. 除CMD外,还有哪些方法可验证MySQL服务可用性? > 引用说明:认证插件修改方法参考MySQL官方文档及服务器配置实践[^2],连接命令规范参考标准操作指南[^1]。
评论
成就一亿技术人!
拼手气红包6.0元
还能输入1000个字符
 
红包 添加红包
表情包 插入表情
 条评论被折叠 查看
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包

打赏作者

终究成为社畜

你的鼓励将是我创作的最大动力

¥1 ¥2 ¥4 ¥6 ¥10 ¥20
扫码支付:¥1
获取中
扫码支付

您的余额不足,请更换扫码支付或充值

打赏作者

实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值