欢迎您访问程序员文章站本站旨在为大家提供分享程序员计算机编程知识!
您现在的位置是: 首页  >  IT编程

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

程序员文章站 2023-11-09 21:04:04
【背景】       最近学习碰到了一件挺令人尴尬的事情,我把mysql的密码给忘记了,所以mysql登录不进去。 &...

【背景】

      最近学习碰到了一件挺令人尴尬的事情,我把mysql的密码给忘记了,所以mysql登录不进去。

      网上的解决方案很多,尝试了很多,依旧是被窗口的各种报错虐。感谢大神的助力,mysql忘记密码解决方案才得以清晰,希望本篇博客的解决过程可以帮到读者。

【问题解决过程】

一、跳过mysql的权限审查进入mysql

      首先,找到mysql的my.ini配置文件。        

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

     然后,打开文件,在mysqld下,添加一句代码 skip-grant-tables ,以跳过权限的审核。    

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

     很重要的一步:win+r 输入services.msc,找到mysql服务,重启服务。

     我怀疑我之前操作的时候,这一步没有执行正确。(而且,这里我也有点疑问,我怎么有两个mysql服务,一个mysql,一个mysql57,mysql属性里没有配置文件,而mysql57是有的。)    

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

二、在mysql.user表中重置密码   

      首先,cmd进入dos窗口,输入mysql,回车。就可以顺利进入mysql,而不需要密码。(我之前连这一步都 实现不了,所以当成功进入mysql的时候,别提我心里多高兴了~~)

      然后,我们再看看mysql.user表里都有啥。 select user,host,authentication_string from mysql.user                    

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

   (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和密码。

update mysql.user set host="%",authentication_string=password('root') where user='root';

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

三、刷新权限,将更改完且处于缓冲区内的数据更新。 flush privileges  

    还有一点小疑问:刷新之后,你直接输入mysql,是没有办法跳过密码审核进入mysql的,但是配置文件明明还没有把那句 skip-grant-tables 注释掉啊?刷新会忽略掉刚才修改的配置文件么?

    反正,后来还是把my.ini里那句 skip-grant-tables 注释了。。            

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

四、使用你的密码登录吧!

    首先,输入 mysql -u root -p ,然后输入刚才设置的密码,你就可以成功进入啦!

    最后,请养成好习惯,记住你的宝贝密码。:)            

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

【小结】

    本来想重新安装mysql的心都有了,但是还是坚持到问题成功解决,过程是有点痛苦,但是结局是美好的。

以上所述是小编给大家介绍的windows 8.1下mysql5.7 忘记root 密码的解决方法,希望对大家有所帮助