ubunt mysql 1698_Ubuntu18 MySql [1698]错误 只能root 登录

在Ubuntu安装完mysql 发现只有使用root权限才能登录,使用普通账号的话会出现如下错误:

~$ mysql -u root -p

Enter password:

ERROR 1698(2000): Access denied for user 'root'@'localhost'

参照了网络很多方法并没有解决

后来不断搜索和尝试终于找到了解决办法

首先使用sudo 进入mysql

~$ sudo mysql -u root

然后查询mysql.user表

mysql> select user, host, plugin FROM mysql.user;

+------------------+-----------+-----------------------+

| user | host | plugin |

+------------------+-----------+-----------------------+

| mysql.session | localhost | mysql_native_password |

| mysql.sys | localhost | mysql_native_password |

| debian-sys-maint | localhost | mysql_native_password |

| root | localhost | auth_socket |

+------------------+-----------+-----------------------+

4 rows in set (0.00 sec)

在此处你将 auth_socket 更新成 mysql_native_password其实并不能解决问题。

这个时候我们需要将root用户删除并重新建立个root 用户并授权,具体操作步骤如下:

mysql> DROP USER 'root'@'localhost';

mysql> CREATE USER 'root'@'%' IDENTIFIED BY 'passwd';

mysql> GRANT ALL PRIVILEGES ON *.* TO 'root'@'%';

然后再刷新权限

mysql> FLUSH PRIVILEGES;

最后

mysql> exit

然后就可以用普通账户登录了。

重新进入后查询user表,具体情况如下:

mysql> select user, host, plugin FROM mysql.user;

+------------------+-----------+-----------------------+

| user | host | plugin |

+------------------+-----------+-----------------------+

| mysql.session | localhost | mysql_native_password |

| mysql.sys | localhost | mysql_native_password |

| debian-sys-maint | localhost | mysql_native_password |

| root | % | mysql_native_password |

+------------------+-----------+-----------------------+

4 rows in set (0.00 sec)

网上查了很久的解决办法,希望对大家有帮助

  • 3
    点赞
  • 0
    收藏
    觉得还不错? 一键收藏
  • 0
    评论

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

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

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值