MySQL重置root用户密码方法

来源:互联网 发布:js round 编辑:程序博客网 时间:2024/05/16 18:09
一直搞不清为什么老是登陆失败,现在总算有点明白了,写出来总结一下。。
第一步:在my.ini里加上skip-grant-tables,我的my.ini文件如下图所示。。。


第二步:关闭服务
以管理员身份运行cmd,然后将路径定位到MySQL的解压路径,我的是D:\MySQL\mysql-5.7.18-winx64\bin,然后输入net stop mysql,回车,即可关闭服务。。
第三步:开启服务
同样的方式,输入net start mysql,回车,即可启动服务。。。
第四步:登陆
同样的方式,输入mysql -u root -p,回车,弹窗出现要输入密码,直接回车,即可出现Welcome界面,表明登陆成功。。。
第五步:打开mysql数据库
输入use mysql,会提示Database changed
第六步:设置密码
输入update user set authentication_string=password('你要设置的密码') where user = 'root';回车,会提示Query OK之类的字眼,表明已经设置OK。
第七步:退出数据库操作
输入exit,回车,会退出到之前的操作目录(我的是D:\MySQL\mysql-5.7.18-winx64\bin)
第八步:将my.ini文件中“skip-grant-tables”注释掉
找到my.ini文件,将“skip-grant-tables”改成“#skip-grant-tables”,即可注释掉,然后保存。。
第九步:关闭服务器
参考第二步。
第十步:开启服务器
参考第三步。
第十一步:登陆
参考第四步。此时就会发现需要输入上述设置的密码才可以进入数据库操作,也说明了密码重置成功。。。

我自己重新设置了一遍,发现又出了新的问题,说什么得切换user。。。

于是又百度了下,http://www.cnblogs.com/debmzhang/p/5013540.html

安装完mysql 之后,登陆以后,不管运行任何命令,总是提示这个

step 1: SET PASSWORD = PASSWORD('your new password');

step 2: ALTER USER 'root'@'localhost' PASSWORD EXPIRE NEVER;

step 3: flush privileges;

完成以上三步退出再登,使用新设置的密码就行了,以上除了红色的自己修改成新密码外,其他原样输入即可

参考1: https://dev.mysql.com/doc/refman/5.6/en/alter-user.html

参考2: http://dev.mysql.com/doc/refman/5.7/en/password-expiration-policy.html

参考3: http://stackoverflow.com/questions/33467337/reset-mysql-root-password-using-alter-user-statement-after-install-on-mac


照着来操作,现在又可以打开之前建立的数据库和数据表了,多谢。。。


0 0