1. 本人mysql版本为mysql-5.7.30-winx64
2. 在mysql安装目录下(本人的为D:\Software\mysql-5.7.30-winx64)打开my.ini文件
3. 在[mysqld]部分的末尾添加skip-grant-tables,意思是启动MySQL服务的时候跳过权限表认证。
如果skip-grant-tables写错位置,会出现如下错误(上面两个错误原因是密码错误):
4. 重启mysql服务(win+R,输入services.msc,点击enter,找到mysql服务,点击重启动)
5. 此时打开cmd窗口,输入mysql -uroot -p(进入mysql安装目录的bin目录下键入该命令,要不要进入bin目录有待确认,不想搞了,有缘者自行确认吧~)
此时会弹出一个Enter password:
不用输任何字符,直接单击enter,然后就可以进入mysql命令行了
6. 修改root账户密码,使用命令update user set password=password(“newPassword”) where user=“root”;会报错
-- 进入mysql数据库,root相关信息在mysql数据库的user表中
use mysql
-- 网上大部分是使用这条命令修改密码,但是我的版本的mysql的user表没有password列,我吐了
update user set password=password("newPassword") where user="root";
查百度发现,5.7 版本password 字段改成authentication_string,password函数还是原来的password函数
-- 修改密码
update user set authentication_string=password("newPassword") where user="root";
-- 更新权限
flush privileges;
7. 退出,使用密码登录
-- 此时在使用无密码登录的会就会报错,如下图所示(有缘者请评论告知本人为何会如此?)
mysql -uroot -p
-- xxx是新密码
mysql -uroot -pxxx
8. 感觉还是要把my.ini中添加的代码删掉比较好,我是删了,你们随意…
-----------结束