Mysql8.0 用户被锁,Account is locked 报错解决

使用root用户给一个账户执行grant命令的时候报了权限问题,然后就查看mysql的user表看看root有哪些权限。发现有几个权限是N,然后顺手就改成了Y。结果一刷新之后就凉凉了。Account is locked。

原因:

于是大致搜了一下,发现是我把user表中的account_locked字段设为了N。

解决:

1、关闭mysql服务:

service mysql stop

2、用安全模式进入:

mysqld_safe --user=mysql --skip-grant-tables --skip-networking &

进入后台运行,然后ctrl + c退出就行。

3、使用免密方式登录mysql:

mysql -uroot

4、登录上之后,执行解除上锁语句

先执行一下 flush privileges 否则会报错: The MySQL server is running with the --skip-grant-tables option so it cannot execute this statement。

flush privileges;
ALTER USER 'root'@'localhost' ACCOUNT UNLOCK;
ALTER USER 'root'@'%' ACCOUNT UNLOCK;
update mysql.user set account_locked='N' where user='root';
commit;

注意要 commit

5、退出mysql,重启服务:

service mysql restart

  • 2
    点赞
  • 10
    收藏
    觉得还不错? 一键收藏
  • 2
    评论

“相关推荐”对你有帮助么?

  • 非常没帮助
  • 没帮助
  • 一般
  • 有帮助
  • 非常有帮助
提交
评论 2
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值