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

 更新时间:2017年07月19日 08:59:41   作者:王璐-Louise  
最近学习碰到了一件挺令人尴尬的事情,我把MySQL的密码给忘记了,所以MySQL登录不进去。在网上找的解决方案都不靠谱,下面小编给大家分享Windows 8.1下MySQL5.7 忘记root 密码的解决方法,需要的朋友一起看看吧

【背景】

      最近学习碰到了一件挺令人尴尬的事情,我把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和密码。

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

 

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

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

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

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

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

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

【小结】

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

以上所述是小编给大家介绍的Windows 8.1下MySQL5.7 忘记root 密码的解决方法,希望对大家有所帮助,如果大家有任何疑问请给我留言,小编会及时回复大家的。在此也非常感谢大家对脚本之家网站的支持!

相关文章

  • 利用mysql的inet_aton()和inet_ntoa()函数存储IP地址的方法分享

    利用mysql的inet_aton()和inet_ntoa()函数存储IP地址的方法分享

    当前很多应用都适用字符串char(15)来存储IP地址(占用16个字节),利用inet_aton()和inet_ntoa()函数,来存储IP地址效率很高,适用unsigned int 就可以满足需求,不需要使用bigint,只需要4个字节,节省存储空间,同时效率也高很多
    2012-03-03
  • MySql 索引、锁、事务知识点小结

    MySql 索引、锁、事务知识点小结

    这篇文章主要介绍了MySql 索引、锁、事务知识点,总结分析了mysql数据库中关于索引、锁和事务的概念、原理、知识点及相关注意事项,需要的朋友可以参考下
    2019-10-10
  • 解决重置Mysql root用户账号密码问题

    解决重置Mysql root用户账号密码问题

    这篇文章主要介绍了解决重置Mysql root用户账号密码问题,本文给大家介绍的非常详细,具有一定的参考借鉴价值,需要的朋友可以参考下
    2019-09-09
  • mysql临时变量的使用

    mysql临时变量的使用

    这篇文章主要介绍了mysql临时变量的使用方式,具有很好的参考价值,希望对大家有所帮助,如有错误或未考虑完全的地方,望不吝赐教
    2024-05-05
  • MySQL通过存储过程来添加和删除分区的过程(List分区)

    MySQL通过存储过程来添加和删除分区的过程(List分区)

    这篇文章主要介绍了MySQL-通过存储过程来添加和删除分区(List分区),本文通过创建存储过程来添加和删除分区,可以避免在分区存在时添加分区报错,或者分区不存在时删除分区报错的问题,需要的朋友可以参考下
    2023-09-09
  • MySQL 8.0 新特性之哈希连接(Hash Join)

    MySQL 8.0 新特性之哈希连接(Hash Join)

    MySQL 开发组于 2019 年 10 月 14 日 正式发布了 MySQL 8.0.18 GA 版本,带来了一些新特性和增强功能。这篇文章主要介绍了MySQL 8.0 新特性之哈希连接(Hash Join),需要的朋友可以参考下
    2019-10-10
  • 关于sql count(列名)、count(常量)、count(*)之间的区别

    关于sql count(列名)、count(常量)、count(*)之间的区别

    这篇文章主要介绍了关于sql count(列名)、count(常量)、count(*)之间的区别及说明,具有很好的参考价值,希望对大家有所帮助,如有错误或未考虑完全的地方,望不吝赐教
    2023-08-08
  • Mysql数据库面试必备之三大log介绍

    Mysql数据库面试必备之三大log介绍

    大家好,本篇文章主要讲的是Mysql数据库面试必备之三大log介绍,感兴趣的同学赶快来看一看吧,对你有帮助的话记得收藏一下
    2021-12-12
  • Mysql的增删改查语句简单实现

    Mysql的增删改查语句简单实现

    这篇文章主要介绍了Mysql的增删改查语句简单实现的相关资料,需要的朋友可以参考下
    2017-04-04
  • SQL语句单引号与双引号的使用方法

    SQL语句单引号与双引号的使用方法

    这篇文章主要介绍了SQL语句中单引号、双引号的使用方法,分别讲述,虽然说的是Insert语句, 但是Select、Update、Delete语句都是一样的,具有一定的参考价值,需要的小伙伴可以参考一下
    2022-03-03

最新评论