mysql 5.7密码忘记如何找回

本文介绍了一种在Windows环境下,通过跳过MySQL权限表认证来重置root用户密码的方法。适用于因长时间未使用本地数据库而导致密码遗忘的情况。

一、场景

  mysql安装后一直使用SQLyog工具操作数据库,工作中大部分时间都是使用测试环境数据库,长久未连接本地数据库导致本地密码忘记,使用下面方法可以找回密码。

二、解决方案

1.Win+R ,输入cmd回车

在这里插入图片描述
以管理员身份进入mysql按照bin目录:
d: 进入d盘 ; cd D:Program Filesmysql-5.7.29-winx64bin
在这里插入图片描述

2.停止mysql服务 : net stop mysql

在这里插入图片描述
输入 mysqld --skip-grant-tables 回车(–skip-grant-tables 是启动mysql时跳过权限表认证)

3. 重新打开新的 cmd 窗口。切换到 bin 目录下,输入mysql回车。

在这里插入图片描述
连接数据库: 输入 use mysql 回车
修改密码:update user set authentication_string=password(‘123456’), password_expired=‘N’ where user=“root”;

刷新权限&退出

输入:flush privileges; 回车。输入:quit 回车 退出。
在这里插入图片描述

4.启动mysql,如果mysql启动失败,可以重启电脑,就可以完美解决了~~
### 如何重置 MySQL 5.7 Root 用户密码 对于 MySQL 5.7 版本,当忘记了 `root` 密码时,可以通过停止 MySQL 服务并以跳过权限表的方式启动来更改密码。 #### 方法一:通过跳过权限表方式修改 关闭当前正在运行的 MySQL 服务。这一步骤通常可以在 Windows 的服务管理器中完成,在 Linux 上则可能需要使用特定的服务控制命令如 `service mysql stop` 或者 `systemctl stop mysqld.service`. 进入 MySQL 安装目录下的 bin 文件夹,并在此处开启一个新的 CMD 窗口: ```bash cd C:\Program Files\MySQL\MySQL Server 5.7\bin\ ``` 接着执行如下命令让 MySQL 跳过授权表启动: ```bash mysqld --console --skip-grant-tables --shared-memory ``` 新开一个 CMD 窗口再次转到相同的路径下, 输入不带密码参数直接登录 MySQL : ```sql mysql -u root ``` 成功连接之后按照下面 SQL 语句操作更新 `root` 用户的新密码[^1]: ```sql USE mysql; UPDATE user SET authentication_string=PASSWORD('新密码') WHERE User='root'; FLUSH PRIVILEGES; EXIT; ``` #### 方法二:利用安全模式修改 如果上述方法遇到困难,则可尝试另一种方案——即先完全停掉 MySQL 服务再重启它的时候加上特殊选项使服务器忽略访问控制列表文件(`--skip-grant-tables`)。此过程允许任何客户端无需身份验证即可连接数据库引擎,从而能够更方便地设置新的超级账户凭证[^3]。 同样的,在另一个终端会话里重复之前提到过的步骤直到获得无认证提示符为止;然后继续执行以下指令刷新权限并赋予全部权利给远程主机上的根用户: ```sql GRANT ALL PRIVILEGES ON *.* TO 'root'@'%' IDENTIFIED BY '新密码'; flush privileges; exit ``` 以上两种途径都可以有效地帮助恢复丢失的管理员级别的登陆信息。值得注意的是,一旦完成了必要的调整动作后应当立即恢复正常的工作流程,移除所有临时性的配置变更以免造成安全隐患。
评论 2
成就一亿技术人!
拼手气红包6.0元
还能输入1000个字符
 
红包 添加红包
表情包 插入表情
 条评论被折叠 查看
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

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

余额充值