Mysql

关注公众号 jb51net

关闭
首页 > 数据库 > Mysql > MySQL Access denied for user

MySQL遇到“ Access denied for user ”问题的解决办法

作者:半桶水专家

这篇文章主要介绍了MySQL遇到“ Access denied for user ”问题的解决办法,文中通过代码示例讲解的非常详细,对大家的解决问题有一定的帮助,需要的朋友可以参考下

1. 检查 MySQL 认证方法

sudo mysql -uroot -p 

然后运行以下查询来查看 root 用户的认证方式:

SELECT user, host, plugin FROM mysql.user WHERE user='root';

如果你看到 auth_socket 插件与 root 用户关联,说明 root 用户使用的是 socket 认证方式。

可以修改认证方式和密码解决,注意,修改了认证方式后密码也要修改

ALTER USER 'root'@'localhost' IDENTIFIED WITH mysql_native_password BY 'new_password';

2. 重置密码(如果使用密码认证)

sudo systemctl stop mysql
sudo mysqld_safe --skip-grant-tables &
mysql -u root
USE mysql;
UPDATE user SET authentication_string=PASSWORD('new_password') WHERE user='root';
FLUSH PRIVILEGES;
sudo systemctl start mysql
mysql -u root -p

3. 检查用户权限

SHOW GRANTS FOR 'root'@'localhost';

如果需要,可以调整权限,例如:

GRANT ALL PRIVILEGES ON *.* TO 'root'@'localhost' WITH GRANT OPTION;
FLUSH PRIVILEGES;

按照上述步骤检查和修复后,应该能够解决 Access denied 错误。

以上就是MySQL遇到“ Access denied for user ”问题的解决办法的详细内容,更多关于MySQL Access denied for user的资料请关注脚本之家其它相关文章!

您可能感兴趣的文章:
阅读全文