| 在安装完 MySQL 或者是在使用 MySQL 时,最尴尬的就是忘记密码了,墨菲定律也告诉我们,如果一件事有可能出错,那么它一定会出错。那如果我们不小心忘记了 MySQL 的密码,该如何处理呢?别着急,本文教你一招搞定。 |

在安装完 MySQL 或者是在使用 MySQL 时,最尴尬的就是忘记密码了,墨菲定律也告诉我们,如果一件事有可能出错,那么它一定会出错。那如果我们不小心忘记了 MySQL 的密码,该如何处理呢?别着急,本文教你一招搞定。
首先我们需要打开 MySQL 的配置文件,如果是 Windows 系统的话,MySQL 的配置文件是 my.ini,它在 MySQL 的默认安装目录下;如果是 MacOS 系统的话,配置文件名是 my.cnf,它的路径是 /etc/my.cnf。
以 MacOS 为例,我们需要在配置文件的 [mysqld] 后面添加“skip-grant-tables”,意思是设置跳过权限验证,如下图所示:

MacOS 可以直接使用“sudo vim /etc/my.cnf” 命令进行配置文件的编辑。
注意事项
在 MacOS 中如果找不到 MySQL 的配置文件,可以直接在 /etc 目录下创建 my.cnf,添加如下内容:
[client] default-character-set=utf8 [mysqld] bind-address = 127.0.0.1 character-set-server=utf8 skip-grant-tables
当然如果有其他配置项的话,也可以自行修改。
在修改完配置文件之后,我们需要重启 MySQL 服务才能让配置生效。
如果是 Windows 系统,我们可以先关闭再启动 MySQL,执行 命令如下:
net stop mysql net start mysql
如果是 Linux 系统,可以直接使用命令重启:
service mysql restart
如果是 Mac 系统,可通过界面进行重启操作,如下图所示:



重启服务之后我们就可以通过命令行工具来设置 MySQL 的新密码了,首先我们输入“mysql -u root -p”命令来连接 MySQL 服务器,当出现输入密码框时直接敲回车就可以登录了,如下图所示:

接下来我们再使用以下命令来设置新的密码:
update user set password=password('新密码') where user='root'; flush privileges; quit
注意事项
如果在执行该步骤的时候出现 ERROR 1290 (HY000): The MySQL server is running with the --skip-grant-tables option so it cannot execute this statement 错误。则需要先执行下 flush privileges 命令,再执行其他命令即可。
当我们设置完新密码之后,记得要把 MySQL 配置文件中的“skip-grant-tables”(跳过权限验证)去掉,然后再重启 MySQL 的服务就可以正常使用了。原文地址:https://www.linuxprobe.com/forgot-mysql-password.html
编辑推荐:
- 啥?你忘记了Mysql密码?03-01
- mysqldump中skip-tz-utc参数介绍03-01
- 14.5.1 Innodb 的锁03-01
- 即将写入MySQL源码的官方bug解决之路03-01
- 如何应对事关业务生死的数据泄露和删改?03-01
- 14.1 InnoDB 存储引擎介绍03-01
- 数据库又出问题了?教你给MySQL做全身体检03-01
- mysql索引原理详解03-01
相关推荐
-
雷神推出 MIX PRO II 迷你主机:基于 Ultra 200H,玻璃上盖 + ARGB 灯效
2 月 9 日消息,雷神 (THUNDEROBOT) 现已宣布推出基于英
-
制造商 Musnap 推出彩色墨水屏电纸书 Ocean C:支持手写笔、第三方安卓应用
2 月 10 日消息,制造商 Musnap 现已在海外推出一款 Oce
热文推荐
- 啥?你忘记了Mysql密码?
啥?你忘记了Mysql密码?
26-03-01 - 14.5.1 Innodb 的锁
14.5.1 Innodb 的锁
26-03-01 - 即将写入MySQL源码的官方bug解决之路
即将写入MySQL源码的官方bug解决之路
26-03-01 - 如何应对事关业务生死的数据泄露和删改?
如何应对事关业务生死的数据泄露和删改?
26-03-01 - 14.1 InnoDB 存储引擎介绍
14.1 InnoDB 存储引擎介绍
26-03-01 - 数据库又出问题了?教你给MySQL做全身体检
数据库又出问题了?教你给MySQL做全身体检
26-03-01 - MySQL:MGR修改max_binlog_cache_size参数导致异常
- MySQL:为什么lsof会看到这么多临时文件
MySQL:为什么lsof会看到这么多临时文件
26-03-01 - Mysql系列第二十三讲 如何正确的使用索引?
Mysql系列第二十三讲 如何正确的使用索引?
26-03-01 - MySQL:关于Wating for Slave workers to free pending events等待
