MySQL登录报错ERROR 1045 (28000): Access denied for user

Ubuntu 下运行

mysql -u root -p

报错显示 ERROR 1698 (28000): Access denied for user ‘root’@‘localhost’ ,原因是root用户空密码,

  1. 登录查看MySQL账户信息
sudo mysql
SELECT User, Host, HEX(authentication_string) FROM mysql.user;

在这里插入图片描述
可以知道root用户一直为空密码,但无论使用何种方式设置密码都是设置不上的。

  1. 原因是MySQL验证密码使用授权插件(使用的授权插件类型可以在mysql.user表中看到)
SELECT user, plugin FROM mysql.user;

在这里插入图片描述

  1. 我们在使用apt命令安装mysql-server时并没有设置root密码(也没有提示设置,无法设置),MySQL就为root用户自定义授权插件为auth_socket插件。

  2. 这个插件不关心也不需要密码,它只是通过UNIX套接字的用户名进行验证,如果验证通过,那么就鉴权成功。这就是root用户可以正常使用mysql的原因,因为root用户在mysql的user表中。

解决方法

重新设置授权插件,并设置密码

update mysql.user set authentication_string=PASSWORD('123456'), plugin='mysql_native_password' where user='root';

在更新的mysql8版本中会提示语法错误,改为

ALTER USER 'username'@'localhost' IDENTIFIED WITH 'mysql_native_password' BY '123456';

附:

mysql跳过认证的方法

  1. 编辑 MySQL 的配置文件,通常为 /etc/mysql/my.cnf 或 /etc/my.cnf
vim /etc/mysql/my.cnf
  1. 在配置文件中找到 [mysqld] 部分,添加一行并保存退出
[mysqld]
skip-grant-tables
  1. 重新启动 MySQL 服务,以使更改生效
sudo service mysql restart

现在,MySQL 将启动并忽略授权表。请记住,启用了 skip-grant-tables 选项后,任何连接到 MySQL 的用户都将具有 root 权限,因此请确保在使用完 skip-grant-tables 后及时禁用它,并重新启动 MySQL 服务。

清除数据库中多余权限记录

如果 SELECT 查询结果显示了一个已经被删除的用户(例如 “wordpress ubuntu”),那么很可能是由于数据库中的权限记录没有被正确清除而导致的。

DELETE FROM mysql.db WHERE Db = 'database_name' AND User = 'username';
  • 1
    点赞
  • 4
    收藏
    觉得还不错? 一键收藏
  • 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、付费专栏及课程。

余额充值