找回丢失的mysql服务的root用户的密码

    一、关闭mysqld服务。服务名称则根据电脑上的实际服务名来决定,windows下则用以管理员身份运行cmd.exe程序,然后输入:net stop mysql的服务名称。

    二、打开一个cmd窗口,以跳过权限检查的方式启动mysql服务。在cmd窗口中输入如下:

mysqld  --defaults-file="C:\ProgramData\MySQL\MySQL Server 5.7\my.ini"  --console --skip-grant-tables。--defaults-file选项指定mysql服务器的默认配置文件。而--skip-grant-tables选项表示忽略权限检查。这个窗口一直开着

   三、更新名称为mysql这个数据库名中的user表中的root用户名的密码字段authentication_string。操作如下:

先开启另一个cmd窗口,然后输入命令:mysql --user=root -p

然后直接回车,不用输入密码

然后查看该服务器上的所有数据库名称,输入命令:show databases;

然后进入名称为mysql的这个数据库,输入命令:use mysql;

然后修改密码:update user set authentication_string=password('1314520') where user='root';

然后刷新权限输入命令:flush privileges;

再退出输入命令:quit;

最后重启服务器:net start mysql57;

   四、到此,mysql服务的root权限的密码重置了。注意上面的authentication_string字段,因版本不同而有所不同,mysql5.7版本的是authentication_string字段,以前的版本有的是password字段;赋值密码时,需要使用数据库自带的password函数,而不能直接赋值为明文密码。

猜你喜欢

转载自www.cnblogs.com/igoodful/p/9013698.html