MySQL登录时出现 Access denied for user ‘root‘@‘xxx.xxx.xxx.xxx‘ (using password: YES) 的原因及解决办法。
初学者经常碰到这种问题,可能原因有:密码错误、权限不足、mysql配置文件限制、应用程序问题。
逐一排查:
情况一有可能是密码错误
是否密码错误,请用工具连接或命令行登录检查密码是否正确。
修改用户密码如下,尤其是root密码:
方法1: 用SET PASSWORD命令
首先登录MySQL。
格式:mysql> set password for 用户名@localhost = password(‘新密码’);
例子:mysql> set password for root@localhost = password(‘123’);
方法2:用mysqladmin
格式:mysqladmin -u用户名 -p旧密码 password 新密码
例子:mysqladmin -uroot -p123456 password 123
方法3:用UPDATE直接编辑user表
首先登录MySQL。
mysql> use mysql;
mysql> update user set password=password(‘123’) where user=‘root’ and host=‘localhost’;
mysql> flush privileges;
方法4:在忘记root密码的时候,可以这样,以windows为例:
关闭正在运行的MySQL服务。
打开DOS窗口,转到mysql\bin目录。
输入mysqld --skip-grant-tables 回车。–skip-grant-tables 的意思是启动MySQL服务的时候跳过权限表认证。
再开一个DOS窗口(因为刚才那个DOS窗口已经不能动了),转到mysql\bin目录。
输入mysql回车,如果成功,将出现MySQL提示符 >。
连接权限数据库: use mysql; 。
改密码:update user set password=password(“123”) where user=“root”;(别忘了最后加分号) 。
刷新权限(必须步骤):flush privileges;
退出 quit。
注销系统,再进入,使用用户名root和刚才设置的新密码123登录。
情况二解决方案 :远程授权

创建用户和授权
先连接数据库,然后执行命令(相关参数new_user、ip_address、password请根据实际修改):
CREATE USER ‘new_user’@‘ip_address’ IDENTIFIED BY ‘password’;
GRANT ALL PRIVILEGES ON . TO ‘new_user’@‘ip_address’;
例如:

情况三、应用程序配置文件问题
数据库链接参数用户名要在密码前面!

111万+

被折叠的 条评论
为什么被折叠?



