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

本文介绍了解决Ubuntu系统中安装MySQL后无法使用root用户登录的问题。通过使用debian-sys-maint用户登录MySQL,更新root用户的密码,并刷新权限。

摘要生成于 C知道 ,由 DeepSeek-R1 满血版支持, 前往体验 >

工具:
mysql  Ver 14.14 Distrib 5.7.25, for Linux (x86_64) 

问题描述:
Ubuntu在安装完成mysql后,无法直接通过mysql -u root -p命令登录mysql,出现如下错误:ERROR 1698 (28000): Access denied for user 'root'@'localhost'

解决方法:

Ubuntu linux下安装新版本mysql,安装时root密码是随机的,因此会出现上述错误。

第一步,登录mysql

既然我们无法通过root用户进入MySQL,那我们就只能通过其他用户登录MySQL了。在我们下载安装MySQL的时候系统给我们创建了一个用户。打开 /etc/mysql/debian.cnf如下。

我们找到client的user和password,然后在终端输入 mysql -u debian-sys-maint -p 然后回车输入 password的内容。这样就进入了MySQL了,如图:

第二步,查看user表

在mysql中输入:select user, plugin from mysql.user,结果如下:

第三步,修改root密码

输入以下命令:update mysql.user set authentication_string=PASSWORD('123'), plugin='mysql_native_password' where user='root';

第四步,刷新

输入以下命令:flush privileges;

然后重新启动服务器,就可以正常登录啦

评论 16
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值