在MySQL登录时出现Access denied for user ‘root‘@‘localhost‘ (using password: YES) 拒绝访问,并可修改MySQL密码

  • 适用于windows安装MySQL

  • 对于出现拒绝访问root用户的解决方案

错误1045(28000):用户'root'@'localhost'(使用密码:YES)拒绝访问

 

首先解析此英文:ERROR 1045 (28000): Access denied for user 'root'@'localhost' (using password: YES);解析的地方有两处:①Access denied(拒绝访问);②using password:NO/YES

一、出现access denied的原因有如下可能:

   1)mysql的服务器停止

   2)用户的端口号或者IP导致  

   3)mysql的配置文件错误----my.ini等文件

   4)root用户的密码错误

  1. 若MySQL已经没有启动,重启MySQL服务器:net start mysql

  2. 若用户的端口号与IP(3306/3307)不一致,打开my.ini文件进行编辑。全部将端口编辑替换为: port=X(如:port=3306)
  3. my.ini文件误输入无效内容,不知道到何处。复制替换该文件;有人已经对my.ini文件进行解释以及注释(非博主的文章)https://blog.csdn.net/lienfeng6/article/details/78140404
  4. root用户密码错误,本博文章主要内容【解决方案】

出现 using password的原因如下是:

  1. 不键入密码:
  2. 错误的密码:
  • 解决方案:

到安装的MySQL的目录下,找my.ini文件;

在[mysqld]后添加skip-grant-tables(使用 set password for设置密码无效,且此后登录无需键入密码)

skip-grant-tables     #在my.ini,[mysqld]下添加一行,使其登录时跳过权限检查

尽量少操作(接着如下操作)     skip-grant-tables

重启MySQL服务器。

登录mysql,键入mysql –uroot –p;直接回车(Enter)

键入无效set password for ‘root’@‘localhost’=password(‘123456’);

在my.ini文件添加从此后无需键入密码

再把my.ini的skip-grant-tables删除,然后重启MySQL服务器:net stop mysql ;net start mysql;

再次进行设置密码:set password for ‘root’@‘localhost’=password(‘123456’);

设置密码成功。

skip-name-resolv        #禁止MySQL对外部连接进行DNS解析,使用这一选项可以消除MySQL进行DNS解析的时候。但是需要注意的是,如果开启该选项,则所有远程主机连接授权都要使用IP地址方式了,否则MySQL将无法正常处理连接请求!

  • 以上仍然不行的话

如果如上仍然不行,

1、卸载计算机上所有与MYSQL相关应用程序

2、删除MYSQL所有配置文件

3、然后安装或者进行相关配置。

 

以上方法仍然行不通,只能请您更换您计算机或者重装操作系统!!!

 

相关推荐
©️2020 CSDN 皮肤主题: 大白 设计师:CSDN官方博客 返回首页