收藏备用,MySQL 8下忘密码后重置密码的办法(MySQL5老方法不灵了)

数据库 MySQL
MySQL的密码是存放在user表里面的,修改密码其实就是修改表中记录。重置的思路是是想办法不用密码进入系统,然后用数据库命令修改表user中的密码记录。

MySQL密码重置思路

MySQL的密码是存放在user表里面的,修改密码其实就是修改表中记录。

重置的思路是是想办法不用密码进入系统,然后用数据库命令修改表user中的密码记录。

查了下,MySQL5系统在网上建议的方法是以--skip-grant-tables参数启动mysql服务,该参数指示在启动时不加载授权表,因此启动成功后root用户可以空密码登陆

mysqld –skip-grant-tables

登陆之后可以用

UPDATE user SET authentication_string='' WHERE user='root';

这类命令设置密码或者将密码置空。

但是,实测mysqld –skip-grant-tables这样的命令行,在mysql8中无法成功启动,而且测试了该参数放在ini文件里面也同样无法启动

收藏备用,MySQL 8下忘密码后重置密码的办法(MySQL5老方法不灵了)

 

MySQL8系统密码重置的两个思路

两条思路,或者用--init-file参数在服务启动时加载并运行修改密码的命令文件,该命令一旦执行,服务启动后密码即已经清除或者重置,启动服务后即可以空密码或指定密码登入。

或者继续研究–skip-grant-tables命令行参数下服务不能启动的原因,解决问题,然后启动服务后以空密码登入,手工输入命令,执行清除或者重置mysql.user表中的密码记录字段。

推荐使用前者。


具体操作流程如下:

方法一:利用--init-file参数解决

该参数指定服务启动时先执行一个包含sql命令文件,因此,只需要将重置密码的命令写在该文件中,以此参数指定启动时执行该命令,启动完成即可重置系统密码了。

第一步,关掉系统服务

net stop mysql

第二步,创建一个文本文件,内含一条密码修改命令

ALTER USER 'root'@'localhost' IDENTIFIED BY '';

第三步:命令行方式启动服务器,指定启动时执行上述的密码修改命令文件

mysqld --init-file=d:mysqlc.txt --console

具体操作截图

收藏备用,MySQL 8下忘密码后重置密码的办法(MySQL5老方法不灵了)

 

方法二,想办法让--skip-grant-tables参数用起来

同方法一,先关掉系统服务

实测,在mysql8系统下,用mysqld --console --skip-grant-tables --shared-memory可以无密码启动服务

收藏备用,MySQL 8下忘密码后重置密码的办法(MySQL5老方法不灵了)

 

服务启动后,以空密码登入系统

mysql.exe -u root

然后执行sql命令将root用户密码设置为空

UPDATE mysql.user SET authentication_string='' WHERE user='root' and host='localhost';

具体操作截图

收藏备用,MySQL 8下忘密码后重置密码的办法(MySQL5老方法不灵了)

 

MySQL8的一些特性导致老方法重置不大管用了,建议使用--init-file参数解决,实测安全可靠。

数据库管理密码丢失是很头疼的事情,如果不能顺利找回,麻烦很大。网上搜索的解决方法多数已经落伍,建议收藏关注本文,以备不时之需。 

责任编辑:庞桂玉 来源: 今日头条
相关推荐

2011-04-07 16:54:42

2018-12-27 13:35:11

MySQLMySQL 8重置密码

2019-09-09 10:25:54

MySQLMariaDB roo密码

2018-09-08 10:16:18

数据库MySQLMariaDB

2010-10-14 11:48:20

MySQL账户密码

2010-05-12 16:56:44

2011-05-18 14:00:44

MySQL默认密码

2010-07-19 13:39:01

CentOSroot重置

2018-07-31 16:20:12

Windows 10Windows密码

2017-04-13 12:20:43

Mysqlroot密码

2016-10-25 20:30:11

2010-05-28 13:48:07

MySQL数据库密码

2017-03-17 15:25:54

LinuxMySQLroot密码

2010-05-13 18:18:58

MySQL root

2010-01-27 09:53:37

2010-06-01 08:54:36

MySQL忘记root

2010-10-14 10:09:33

MySQL root用

2010-05-25 16:37:47

MySQL忘记密码

2024-11-25 18:53:55

Linux

2019-10-09 16:08:21

PythonPython教程Python 开发
点赞
收藏

51CTO技术栈公众号