MySQL登录报错 ERROR 1045 (28000)

MySQL登录报错 ERROR 1045 (28000)

背景:由于业务需求,需要对MySQL数据库进行升级,从原来的5.6.36升级到5.7.1.21,在将低版本库的数据进行全库导出后,导入高版本库中,在登录时报密码错误。
1、现象:
[root@localhost ~]# mysql -u root -p
Enter password: 

ERROR 1045 (28000): Access denied for user 'root'@'localhost' (using password: YES)

2、原因:数据库中存在空用户所致

3、解决方案:

方案一:
1)停用mysql服务:# service mysql stop
2)输入命令:# mysqld_safe --user=mysql --skip-grant-tables --skip-networking & 
3)登入数据库:# mysql -u root mysql
4)mysql> use mysql;
5)mysql> select user,host,password from user; 结果如下:
+------+-----------------------+----------+
| user | host                  | password |
+------+-----------------------+----------+
| root | %                           | mima  |
| root | localhost.localdomain | mima  |
| root | 127.0.0.1                 | mima  |
|        | localhost                  |          |
|        | localhost.localdomain |          |
+------+-----------------------+----------+
6)将上面查询出来的空用户删除:mysql> delete from user where user='';
7)退出数据库:mysql> quit
8)启动mysql服务:# service mysql start
9)重新用命令‘mysql -u root -p’登录,OK!
方案二:
1)找到mysql的配置文件,修改my.cnf,在其中加入skip-grant-tables
2)重启数据库service mysql restart
3)免密码使用root登录,然后查看user表、删除空用户
4)推出数据库,修改my.cnf,去掉skip-grant-tables
5)重启数据库
方案三:
1)找到mysql的配置文件,修改my.cnf,在其中加入skip-grant-tables
2)重启数据库service mysql restart
3)免密码使用root登录
4)更新密码
update user set password=password("新密码") where user="root";   (密码自己设)
5)刷新数据库
flush privileges;      刷新数据库
quit;
6)修改my.cnf ,注释掉skip-grant-tables(以防下次出问题)
保存退出
7)重启MySQL服务(步骤二)。
  • 1
    点赞
  • 7
    收藏
    觉得还不错? 一键收藏
  • 0
    评论
MySQL登录报错 ERROR 1045 (28000): Access denied for user 'root'@'localhost' (using password: NO) 是由于MySQL拒绝了使用root用户在本地主机上登录的请求,原因可能是密码错误或者没有设置密码。这个错误通常出现在以下几种情况下: 1. 密码错误:如果你尝试使用root用户登录MySQL时没有输入密码,或者输入的密码不正确,就会出现这个错误。请确保输入的密码是正确的。 2. 没有设置密码:如果你尝试使用root用户登录MySQL时没有设置密码,也会出现这个错误。在某些情况下,MySQL默认是没有设置root用户的密码的。你可以尝试使用空密码登录,或者通过修改MySQL配置文件来设置密码。 解决这个问题的方法有以下几种: 1. 使用正确的密码:确保你输入的密码是正确的。如果你不确定密码是否正确,可以尝试重置root用户的密码。 2. 设置密码:如果你尝试使用root用户登录时没有设置密码,可以通过以下步骤来设置密码: - 打开命令行或终端窗口,并以管理员身份运行。 - 输入以下命令来连接到MySQL服务器:mysql -u root - 输入以下命令来设置root用户的密码:ALTER USER 'root'@'localhost' IDENTIFIED BY 'new_password'; (将new_password替换为你想要设置的新密码) - 输入以下命令来刷新权限:FLUSH PRIVILEGES; 3. 重置密码:如果你忘记了root用户的密码,可以通过以下步骤来重置密码: - 停止MySQL服务。 - 打开命令行或终端窗口,并以管理员身份运行。 - 输入以下命令来启动MySQL服务并跳过权限验证:mysqld_safe --skip-grant-tables & - 连接到MySQL服务器:mysql -u root - 输入以下命令来重置root用户的密码:UPDATE mysql.user SET authentication_string=PASSWORD('new_password') WHERE User='root'; (将new_password替换为你想要设置的新密码) - 输入以下命令来刷新权限:FLUSH PRIVILEGES; - 退出MySQL并重新启动MySQL服务。

“相关推荐”对你有帮助么?

  • 非常没帮助
  • 没帮助
  • 一般
  • 有帮助
  • 非常有帮助
提交
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值