UPDATE user SET authentication_string=PASSWORD('new_password') WHERE User='root';
FLUSH PRIVILEGES;
复制代码
退出并重启 MySQL 服务:
sudo systemctl restart mysqld
复制代码
5. 检查 IDEA 的数据库设置
打开 IDEA 的 Database 工具窗口。
检查连接设置:
Host: localhost 或 127.0.0.1
Port: 3306(默认端口)
User: root
Password: 你的暗码
Database: 可选,如果未指定则连接默认数据库。
测试连接:
点击 Test Connection,确保连接成功。
6. 检查防火墙
如果 MySQL 运行在长途服务器上,确保防火墙答应 MySQL 端口(默认 3306)的访问:
Linux:
sudo ufw allow 3306/tcp
复制代码
Windows:
在防火墙设置中答应 mysqld.exe 或端口 3306。
7. 其他大概的原因
MySQL 版本问题:
某些 MySQL 版本(如 8.0+)默认利用 caching_sha2_password 加密方式,大概导致连接问题。
修改加密方式:
ALTER USER 'root'@'localhost' IDENTIFIED WITH mysql_native_password BY 'your_password';
FLUSH PRIVILEGES;
复制代码
IDEA 插件问题:
确保已安装并启用了 Database Tools and SQL 插件。
总结
通过以上步调,可以解决 Access denied for user 'root'@'localhost' (using password: YES) 错误。如果问题仍未解决,请检查 MySQL 的错误日志(通常位于 /var/log/mysql/error.log 或 C:\ProgramData\MySQL\MySQL Server X.X\Data\*.err),获取更多具体信息。