很多刚安装完MySQL的新手在第一次尝试登录数据库时,经常会碰到error1045的错误提示,导致无法进入数据库操作界面,影响后续的学习和使用。下面先给大家展示一张MySQL报错error1045的示例图:

error1045错误的含义
MySQL的error1045错误完整提示通常是ERROR 1045 (28000): Access denied for user 'root'@'localhost' (using password: YES/NO),这个错误的核心含义是数据库服务器拒绝了当前的登录请求,本质是身份验证环节出现了问题。
首次使用出现error1045的常见原因
- 安装完成后没有正确获取初始root密码,或者输入的密码和初始密码不匹配
- MySQL服务没有正常启动,导致登录请求无法被正确响应
- 初始化时root账户的权限配置异常,或者host字段限制导致本地登录被拒绝
- 登录时指定的用户名、端口或者host参数和实际配置不符
不同系统下的解决方法
Windows系统解决步骤
首先停止MySQL服务,可以通过命令行执行以下命令:
-- 停止MySQL服务,服务名根据实际安装情况可能是mysql或者mysql80等 net stop mysql
然后进入MySQL的安装目录的bin文件夹,执行跳过权限验证的启动命令:
-- 跳过权限表启动MySQL,此时登录不需要密码 mysqld --console --skip-grant-tables --shared-memory
保持这个窗口运行,新开一个命令行窗口,直接输入mysql登录:
-- 无密码登录root账户 mysql -u root
登录成功后,执行修改密码的操作:
-- 切换到mysql系统数据库
use mysql;
-- 修改root账户密码,注意MySQL不同版本密码字段可能不同,5.7及以上版本是authentication_string
update user set authentication_string=password('新密码') where user='root';
-- 刷新权限
flush privileges;
-- 退出数据库
exit;之后关闭跳过权限的MySQL窗口,重启正常的MySQL服务,用新密码登录即可。
Linux系统解决步骤
首先停止MySQL服务:
# 停止MySQL服务 systemctl stop mysqld
修改MySQL配置文件/etc/my.cnf,在[mysqld]模块下添加skip-grant-tables:
# 编辑配置文件 vim /etc/my.cnf # 在[mysqld]下添加以下内容 [mysqld] skip-grant-tables
启动MySQL服务后无密码登录:
-- 启动服务 systemctl start mysqld -- 无密码登录 mysql -u root
登录后修改密码,注意MySQL 8.0及以上版本修改密码的语法有变化:
-- 切换到mysql数据库 use mysql; -- MySQL 8.0及以上版本修改密码语法 alter user 'root'@'localhost' identified by '新密码'; -- 刷新权限 flush privileges; -- 退出 exit;
之后删除my.cnf中添加的skip-grant-tables配置,重启MySQL服务即可正常登录。
预防error1045的注意事项
- 安装MySQL时记下初始密码,或者安装完成后第一时间修改为自己熟悉的密码
- 登录时确认用户名、端口、host参数是否正确,本地登录默认用localhost
- 不要随意修改mysql系统库的user表权限,除非明确知道操作的影响
- 如果忘记了密码,按照上述跳过权限的方式重置即可,不要反复尝试错误密码导致账户被锁定
注意:跳过权限验证的方式仅用于密码重置等特殊情况,操作完成后一定要关闭跳过权限的配置,避免数据库存在安全风险。