美文网首页MySQL
mysql8.0以上忘记密码如何登陆,以及登陆之后修改密码。

mysql8.0以上忘记密码如何登陆,以及登陆之后修改密码。

作者: 庄晓铭 | 来源:发表于2020-09-22 17:13 被阅读0次

    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文件里面也同样无法启动

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

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

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

    推荐使用前者。

    具体操作流程如下:

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

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

    第一步,关掉系统服务

    net stop mysql

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

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

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

             mysqld --init-file=D:\Program Files (x86)\Mysql\mysql-8.0.21-winx64\c.txt --console     #这里的d:mysqlc.txt要改成你袭击的文件的路径

    具体操作截图

     注意:当出现上图相似的,并且cmd已经不动了,你再用管理员身份重新打开一个新的cmd(刚才这个cmd不要关闭),再mysql.exe -u root,进入mysql界面,然后修改密码。最后,请再打开mysql服务,net start mysql ,否则还会出现连接不上,密码错误的提示,导致mysql进不去.

    修改密码方法:https://blog.csdn.net/huang1600301017/article/details/84844090

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

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

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

    服务启动后,以空密码登入系统(打开另外一个cmd)

    mysql.exe -u root

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

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

    具体操作截图

    相关文章

      网友评论

        本文标题:mysql8.0以上忘记密码如何登陆,以及登陆之后修改密码。

        本文链接:https://www.haomeiwen.com/subject/lyowyktx.html