MySQL8下忘记密码后重置密码的办法(MySQL老方法不灵了)

作者:代码湾 时间:2024-01-17 11:38:49 

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

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下忘记密码后重置密码的办法(MySQL老方法不灵了)

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

具体操作截图

MySQL8下忘记密码后重置密码的办法(MySQL老方法不灵了)

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

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

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

MySQL8下忘记密码后重置密码的办法(MySQL老方法不灵了)

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

mysql.exe -u root

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

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

具体操作截图

MySQL8下忘记密码后重置密码的办法(MySQL老方法不灵了)

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

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

来源:http://codebay.cn/post/9447.html

标签:MySQL8,忘记密码
0
投稿

猜你喜欢

  • 详解C#把DataTable中数据一次插入数据库的方法

    2024-01-17 20:23:51
  • ASP Session对象的集合以及属性方法事件

    2009-02-02 09:26:00
  • Perl操作系统环境变量的脚本代码

    2022-12-27 12:17:22
  • 一文带你理解MySql中explain结果filtered

    2024-01-19 23:01:35
  • Python自动化构建工具scons使用入门笔记

    2023-09-21 19:58:16
  • 使用Tensorflow将自己的数据分割成batch训练实例

    2023-06-14 08:18:07
  • Go到底能不能实现安全的双检锁(推荐)

    2024-04-26 17:36:49
  • 用Python实现等级划分

    2022-10-11 23:45:21
  • python中numpy基础学习及进行数组和矢量计算

    2023-01-22 16:32:04
  • Python tkinter 下拉日历控件代码

    2023-10-25 06:07:18
  • D3.js实现绘制折线图的教程详解

    2024-04-10 10:53:54
  • 纯CSS在Firefox模拟text-overflow: ellipsis效果

    2009-03-17 12:49:00
  • 使用Python获取字典键对应值的两种方法

    2022-08-04 05:25:16
  • 通过AngularJS实现图片上传及缩略图展示示例

    2024-05-02 17:39:52
  • Python处理json字符串转化为字典的简单实现

    2022-05-15 01:42:58
  • python3 删除所有自定义变量的操作

    2023-09-26 03:26:08
  • Python实现arctan换算角度的示例

    2023-07-16 20:31:28
  • Golang 编译成DLL文件的操作

    2024-05-09 09:55:30
  • PHP检查端口是否可以被绑定的方法示例

    2024-05-13 09:26:32
  • Python字符串转换成浮点数函数分享

    2022-10-04 01:04:37
  • asp之家 网络编程 m.aspxhome.com