Centos 下mysql用户丢失,root账号在本地登录

在本地打开mysql -u root -p
无论输入什么密码都错误,又改了密码结果还是不行

后来搜了百度都没有什么好的解决方法。
发现mysql库中的user表缺少一个root指向host

怎么确定你也是这个问题呢?这样做:

  1. vim /etc/my.cnf
    在[mysqld]的段中加上一句:skip-grant-tables
    例如:
    [mysqld]
    datadir=/var/lib/mysql
    socket=/var/lib/mysql/mysql.sock
    skip-grant-tables
    保存并且退出vi。

  2. mysql
    进入mysql命令
    use mysql;
    select user,host,password from user where user=’root’;

| root | % | **** |
| root | ut12313 | *** |
| root | 127.0.0.1 | ****|
可见没有host是localhost的
update user set host=’localhost’ where user=’root’ and host=’ut12313’;

然后把先前第一部的还原,然后设置密码,或者原密码登陆即可。

  • 1
    点赞
  • 0
    收藏
    觉得还不错? 一键收藏
  • 0
    评论
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值