Mysql 密码过期导致无法登陆

1、停止当前mysql服务
2、mysqld --defaults-file="C:/ProgramData/MySQL/MySQL Server 5.7/my.ini"  --skip-grant-tables
一定是my.ini,我一开始找到Program Files下面的my-default.ini去了,可以再服务中右击属性查看一下,就是这个。
这句话貌似是在命令窗口中开了一个mySQL的服务,该命令通过跳过权限安全检查,开启mysql服务,这样连接mysql时,可以不用输入用户密码。
3、win+R,新开一个cmd窗口,原来的别关了呀。
输入命令:
mysql -uroot -p
出现:
Enter password:
在这里直接回车,不用输入密码。
然后就就会出现登录成功的信息。
然后在这里登SQLyog就可以登进去了耶
4、重置root密码:update mysql.user set password=password("123456") where user='root';
5、切换到第一个命令行窗口运行:mysqladmin -u root shutdown
6、启用原本的服务
7、登陆:mysql -uroot -p123456
7、修改密码以能够在客户端登陆:set password for root@localhost = password('123');
8、 修改root密码永不过期:ALTER USER 'root'@'localhost' PASSWORD EXPIRE NEVER;


你可能感兴趣的:(MySql)