Access denied for user root @ localhost (using password: YES)

简述:在学习ssm时,某次打开idea,发现执行数据库的操作时会报如下错误:

Connection; nested exception is java.sql.SQLException: Access denied for user 'root'@'localhost' (using password: YES)

刚开始以为是我的配置文件写错了,经过多次检查,我意识到问题并不是这个。于是我找了很多帖子,发现叫修改配置文件,或者各种方法,但是我的问题还是不能得到解决。前前后后花了3个半小时,期间还经历了重装数据库,最后我发现重装连不能解决问题(重装也会在登陆时继续报改错)。在最后的迷茫之际,终于得到了解决,方法如下:


1:打开数据库安装路径,修改配置文件 my.ini ,在[mysqld]后面添加如下内容

skip-grant-tables

2:以管理员方式打开cmd,输入如下内容回车,停止数据库服务

net stop mysql

3:使用cmd命令进入mysql安装路径下的bin文件夹中,输入如下内容即可进入数据库(不需要输入密码)

mysql -u root -p

4:使用mysql数据库

use mysql;

5:将密码置空

update user set authentication_string='' where user='root';

6:刷新权限

flush privileges;

7:设置加密规则并更新新密码,授权(直接复制这些SQL语句你的密码会更新为123456)

ALTER USER 'root'@'localhost' IDENTIFIED BY '123456' PASSWORD EXPIRE NEVER; 
alter user 'root'@'localhost' identified by '123456';
grant all privileges  on *.*  to "root"@'localhost';
flush privileges;

8:打开配置文件,将刚刚插入的内容删除并保存,退出文件

9:重启数据库

net start mysql

问题应该就可以解决啦!!!ps:第一次写博客,不会排版请见谅。

  • 27
    点赞
  • 289
    收藏
    觉得还不错? 一键收藏
  • 13
    评论
评论 13
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值