今天在正常打开mysql的时候突然提示:Access denied for user ‘root’@’localhost’ (using password: YES)

在网上搜索了很多文章,尝试了他们的解决方法,发现都没有什么效果,最后结合多个方法的重点进行尝试发现完美解决。

第一步:先将Mysql服务停止运行,这一步很重要

第二步:在Mysql的安装路径中找到my.ini 文件,右键编辑,在 mysqld 下面输入跳过密码检测

skip-grant-tables

保存退出文件,切记 切记保存。

第三步:以管理员运行 cmd 也就是俗称的:黑窗口。一定要以管理员运行

第四步:在cmd中输入命令行 mysqld –console –skip-grant-tables –shared-memory

第五步:再次以管理员运行打开cmd。第二个黑窗口。直接输入 mysql 就进入MySQL里面了

第六步:执行命令:update user set authentication_string =” where user = ‘root’; 清空密码。因为MySql8+, 和以前版本有点不同,user表没有password字段了,而是authentication_string 。

第七步:输入指令:flush privileges; 使改变生效。 exit 退出mysql。

第八步:两个黑窗口都进行关闭,在重新运行两个黑窗口 :第三步至第五步再来一遍

第九步:mysql窗口使用指令:ALTER user ‘root’@’localhost’ IDENTIFIED BY ‘123’; 将密码设为123. 就OK了。

最后的最后 将my.ini 文件中的skip-grant-tables 加上#注释掉就行了,重启mysql服务,就可以进了