MySQL报错ERROR 1045 (28000): Access Denied的终极解决方案

 更新时间:2025年12月03日 09:58:22   作者:端宙架构师  
这篇文章主要介绍了如何在mac上重置MySQL root密码的步骤,包括跳过权限验证进入MySQL、更新密码、恢复权限表、检查用户权限和验证MySQL路径,需要的朋友可以参考下

mac 数据库又忘记密码了,记录一下更改密码! 核心思路是:

  1. 跳过权限验证进入 MySQL。
  2. 修复用户或密码。
  3. 恢复权限表。

错误场景复现

执行以下命令时被拒绝访问:

mysql -u root -p < /var/lib/mysql-files/reset.sql
# 或
sudo /usr/local/mysql/bin/mysql -u root -p < /var/lib/mysql-files/reset.sql

输入密码后提示:

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

原因分析

  1. 密码错误:输入的 root 密码不正确。
  2. 权限缺失root@localhost 用户不存在或权限被限制。
  3. MySQL 服务异常:权限表未正确加载或损坏。
  4. 路径问题:使用了错误的 MySQL 客户端或服务路径。

解决方案(亲测有效)

步骤 1:重置 root 密码(核心步骤)

停止 MySQL 服务

sudo /usr/local/mysql/support-files/mysql.server stop

如果提示找不到命令,尝试:

sudo brew services stop mysql  # Homebrew 安装的 MySQL

以安全模式启动 MySQL(跳过权限验证)

sudo /usr/local/mysql/bin/mysqld_safe --skip-grant-tables &

成功启动后,终端会卡住(显示 Starting mysqld daemon with databases...),这是正常现象。

无密码登录 MySQL

/usr/local/mysql/bin/mysql -u root

更新 root 密码(MySQL 5.7+):

FLUSH PRIVILEGES;
ALTER USER 'root'@'localhost' IDENTIFIED BY '你的新密码';
FLUSH PRIVILEGES;
exit;

如果报错 ERROR 1396,可能是用户不存在,需先创建用户(见步骤 2)。

重启 MySQL 服务

sudo /usr/local/mysql/support-files/mysql.server restart

步骤 2:检查 root 用户权限(备用方案)

如果重置密码后仍无法登录,可能是 root@localhost 用户不存在或权限不足:

以安全模式登录后执行:

SELECT host, user FROM mysql.user;

如果缺少 root@localhost,手动创建:

CREATE USER 'root'@'localhost' IDENTIFIED BY '你的密码';
GRANT ALL PRIVILEGES ON *.* TO 'root'@'localhost' WITH GRANT OPTION;
FLUSH PRIVILEGES;

步骤 3:验证 MySQL 路径

确认客户端路径是否正确:

which mysql
# 应返回 /usr/local/mysql/bin/mysql 或 /usr/local/opt/mysql/bin/mysql

如果路径不一致,使用绝对路径执行命令:

sudo /usr/local/mysql/bin/mysql -u root -p

步骤 4:检查文件权限

确保 reset.sql 文件可读:

ls -l /var/lib/mysql-files/reset.sql
sudo chmod 644 /var/lib/mysql-files/reset.sql  # 如果权限不足

步骤 5:查看 MySQL 错误日志

定位更深层次的问题:

sudo tail -n 50 /usr/local/mysql/data/*.err

到此这篇关于MySQL报错ERROR 1045 (28000): Access Denied的终极解决方案的文章就介绍到这了,更多相关MySQL报错ERROR 1045内容请搜索脚本之家以前的文章或继续浏览下面的相关文章希望大家以后多多支持脚本之家!

相关文章

  • MySQL删除binlog日志文件的三种实现方式

    MySQL删除binlog日志文件的三种实现方式

    本文介绍了三种删除MySQL binlog日志文件的方法,包含手动删除、使用SQL命令删除和设置自动清理,具有一定的参考价值,感兴趣的可以了解一下
    2025-02-02
  • Mysql5.7并发插入死锁问题解决

    Mysql5.7并发插入死锁问题解决

    死锁是数据库并发控制中的一种现象,它涉及多个事务在执行过程中相互等待对方占有的资源,导致无法继续执行,本文就来介绍一下Mysql5.7并发插入死锁问题解决,感兴趣的可以了解一下
    2024-09-09
  • MYSQL导入导出sql文件简析

    MYSQL导入导出sql文件简析

    这篇文章主要介绍了MYSQL导入导出.sql文件的相关资料,内容包括MYSQL的命令行模式的设置、命令行进入MYSQL的方法、数据库导出数据库文件、从外部文件导入数据到数据库,感兴趣的小伙伴们可以参考一下
    2016-04-04
  • navicat连接mysql时出现1045错误的解决方法

    navicat连接mysql时出现1045错误的解决方法

    这篇文章主要为大家详细介绍了navicat连接mysql时出现1045错误的解决方法,具有一定的参考价值,感兴趣的小伙伴们可以参考一下
    2017-02-02
  • 深入研究mysql中的varchar和limit(容易被忽略的知识)

    深入研究mysql中的varchar和limit(容易被忽略的知识)

    这篇文章主要介绍了深入研究mysql中的varchar和limit(容易被忽略的知识),本文探究了varchar(5)可以存储多少个汉字、多少个字母数字和mysql中的limit你真的会用吗两个知识点,需要的朋友可以参考下
    2015-03-03
  • MySql常用数据类型与操作详解

    MySql常用数据类型与操作详解

    MySQL 是最流行的关系型数据库管理系统,在WEB应用方面 MySQL 是最好的。本文将为大家详细介绍一下MySQL的基础操作,需要的可以参考一下
    2022-07-07
  • MySQL定时器常用案例

    MySQL定时器常用案例

    这篇文章主要介绍了MySQL定时器的相关知识,本文结合使用案例给大家讲解的非常详细,对大家的学习或工作具有一定的参考借鉴价值,需要的朋友可以参考下
    2023-07-07
  • MySql常用查询命令操作大全

    MySql常用查询命令操作大全

    本文给大家收集整理了MySql常用查询命令操作大全,非常不错,具有参考借鉴价值,需要的朋友参考下吧
    2017-11-11
  • JDBC数据库的使用操作总结

    JDBC数据库的使用操作总结

    本篇文章介绍了,JDBC数据库的使用操作方法的一些总结。需要的朋友可以参考一下
    2013-05-05
  • 将数据插入到MySQL表中的详细教程

    将数据插入到MySQL表中的详细教程

    这篇文章主要介绍了将数据插入到MySQL表中的详细教程,文中给出了在PHP脚本中操作的示例,是MySQL入门学习中的基础知识,需要的朋友可以参考下
    2015-05-05

最新评论