时间:2021-05-23
【背景】
最近学习碰到了一件挺令人尴尬的事情,我把MySQL的密码给忘记了,所以MySQL登录不进去。
网上的解决方案很多,尝试了很多,依旧是被窗口的各种报错虐。感谢大神的助力,MySQL忘记密码解决方案才得以清晰,希望本篇博客的解决过程可以帮到读者。
【问题解决过程】
一、跳过MySQL的权限审查进入MySQL
首先,找到MySQL的my.ini配置文件。
然后,打开文件,在mysqld下,添加一句代码 skip-grant-tables ,以跳过权限的审核。
很重要的一步:win+R 输入services.msc,找到mysql服务,重启服务。
我怀疑我之前操作的时候,这一步没有执行正确。(而且,这里我也有点疑问,我怎么有两个MySQL服务,一个MySQL,一个MySQL57,MySQL属性里没有配置文件,而MySQL57是有的。)
二、在mysql.user表中重置密码
首先,cmd进入DOS窗口,输入MySQL,回车。就可以顺利进入MySQL,而不需要密码。(我之前连这一步都 实现不了,所以当成功进入MySQL的时候,别提我心里多高兴了~~)
然后,我们再看看mysql.user表里都有啥。 select user,host,authentication_string from mysql.user
(Tips:一开始查询 password,发现这个字段是不存在,后来上网查才知道MySQL5.7 把password的字段给换掉了,换成了authentication_string<中文含义 认证字符串>。)
=================================
此处,对host进行一下了解。
Host列指定了允许用户登录所使用的IP范围。
比如user=root Host=192.168.21.1。这里的意思就是说root用户只能通过192.168.21.1的客户端去访问。而%是个通配符,如果Host=192.168.1.%,那么就表示只要是IP地址前缀为“192.168.21.”的客户端都可以连接。如果Host=%,表示所有IP都有连接权限。所以要开启远程连接的时候,大部分人都直接把Host改成%的缘故,因为这样超级方便。
=================================
很重要的一步:我们设置一下host和密码。
三、刷新权限,将更改完且处于缓冲区内的数据更新。 flush privileges
还有一点小疑问:刷新之后,你直接输入mysql,是没有办法跳过密码审核进入MySQL的,但是配置文件明明还没有把那句 skip-grant-tables 注释掉啊?刷新会忽略掉刚才修改的配置文件么?
反正,后来还是把my.ini里那句 skip-grant-tables 注释了。。
四、使用你的密码登录吧!
首先,输入 mysql -u root -p ,然后输入刚才设置的密码,你就可以成功进入啦!
最后,请养成好习惯,记住你的宝贝密码。:)
【小结】
本来想重新安装MySQL的心都有了,但是还是坚持到问题成功解决,过程是有点痛苦,但是结局是美好的。
以上所述是小编给大家介绍的Windows 8.1下MySQL5.7 忘记root 密码的解决方法,希望对大家有所帮助,如果大家有任何疑问请给我留言,小编会及时回复大家的。在此也非常感谢大家对网站的支持!
声明:本页内容来源网络,仅供用户参考;我单位不保证亦不表示资料全面及准确无误,也不保证亦不表示这些资料为最新信息,如因任何原因,本网内容或者用户因倚赖本网内容造成任何损失或损害,我单位将不会负任何法律责任。如涉及版权问题,请提交至online#300.cn邮箱联系删除。
在上篇文章给大家介绍了Mysql5.7忘记root密码及mysql5.7修改root密码的方法Mysql5.7忘记密码快速且简单的解决方法,具体方法详情如下所示
推荐阅读:Mysql5.7忘记root密码及mysql5.7修改root密码的方法Mac安装和卸载Mysql5.7.11的方法系统是cenos6.764位的,默
mysql数据库忘记了root密码是件很痛苦的事,本文介绍如何解决windows环境下mysql服务器忘记root密码的解决方法。1.关闭MySQL服务wind
一、问题linux下的mysql5.7忘记密码二、解决•第一步:打开mysql5.7的配置文件my.cnf,并在里面增加一行:skip-grant-
mysql5.7忘记root密码的操作步骤:1、在系统偏好设置中停止MySQL服务。2、执行命令以安全模式启动MySQL:cd/usr/local/mysql/