Mysql重置root密码遇到的坑(忘记密码)

1、原理

通过配置参数“skip_grant_tables”在mysql启动时跳过grant_tables(授权表),从而通过命令来充值root帐号的密码

2、方式

首先需要停止mysql服务

(1)在my.ini文件的[mysqld]块下增加“skip_grant_tables”,然后重启mysql服务,再以管理员权限打开cmd执行一些列命令重置密码

步骤如下:

A、找到my.ini文件(右击mysql服务找到可执行文件路径,从所在的目录或其它层级目录搜索),在[mysqld]块下增加“skip_grant_tables”

B、重启mysql服务

C、以管理员权限打开cmd命令窗口,执行mysql -uroot –p直接回车不用输入密码

D、选择数据库:use mysql

E、更新root的密码:update user set authentication_string=password('新密码') where user='root' and Host='localhost'

F、刷新权限:flush privileges

G、退出:quit

H、重新登录:mysql -uroot -p提示输入密码,这时输入密码才能登录

I、回到 my.ini 配置文件移除“skip_grant_tables”,再重启mysql

 

(2)直接通过命令指定参数“skip_grant_tables”启动mysql,再执行命令修改密码(与1的步骤除了指定跳过授权表参数的方式不同以外,其它都一样)

A、在第一个cmd窗口执行 mysqld --defaults-file="C:\ProgramData\MySQL\MySQL Server 5.7\my.ini" --skip-grant-tables   ---注意路径(以你的实际情况为准)

其它步骤同上

参考:

Windows下MySQL5.7 root 密码重置

https://blog.csdn.net/hey_yf/article/details/80024706

Windows下Mysql5.7忘记root密码的解决方法

https://www.cnblogs.com/yuwentims/p/9172463.html

3、遇到的坑

同过修改my.ini的方式配置“skip_grant_tables”再保存千万要注意编码的格式“ANSI”

(1)用Notepad++将修改了my.ini的配置

(2)重启mysql服务,就启动不了(超时),通过命令去执行接下来的操作会报“ERROR 1045 (28000): Access denied for user 'ODBC'@'localhost' (using password: NO)”的错误

(3)第一想到的是去百度,无果后从系统事件日志开始着手,发现了一些莫名其它的错误(其实部分是系统里其它程序的错误日志):

A、首先根据关键字看到的是“服务 MySQL57 意外停止。这发生了 7 次。”并没卵用

B、然后就在这个错误的隔壁找其它错误 “应用程序-特定 权限设置并未向在应用程序容器 不可用 SID (不可用)中运行的地址 LocalHost (使用 LRPC) 中的用户 NT AUTHORITY\LOCAL SERVICE SID (S-1-5-19)授予针对 CLSID ”像这种不明不白的错误头脑一发热并没有多想,然后就是百度解决并没有屁用

解决方式:

https://www.cnblogs.com/ibgo/p/3550674.html

http://www.ntxz.net/?p=580

解决了这个日志,但是对mysql并没影响,现在才明白找错了方向

(4)于是将所有的事件日志清除,重启computer

(5)终于发现了一条这样的错误 “mysql 启动报错--发现系统错误2,系统找不到指定的文件”

解决方式:

https://blog.csdn.net/Marvel__Dead/article/details/63262641?locationNum=4&fps=1

解决了报错,mysql服务可以启动了

接着执行重置的命令,终于报了一条有意义的错“Found option without preceding group in config file:XXX; Fatal error in defaults handling.“,找到了原来是my.ini编码惹得祸!

 

改成ANSI,一切就顺利了…

参考:

MySQL报错: Found option without preceding group in config file:XXX; Fatal error in defaults handling.

https://blog.csdn.net/life_android/article/details/56512606

4、注意

(1)确保服务里只有一个MySql

 

posted on 2018-08-19 02:42  村_长  阅读(24945)  评论(2编辑  收藏  举报

导航