Navicat连MariaDB报1045错误通常因权限配置不当而非密码错误:需确认连接方式(localhost/socket vs 127.0.0.1/TCP),检查root用户Host值,用GRANT授权并FLUSH PRIVILEGES,避免直接UPDATE表;云环境注意Navicat连接设置及skip-networking配置。Navicat连MariaDB报1045: Access denied for user 'root'@'localhost',先别急着重置密码绝大多数情况下,这个错误不是密码真错了,而是权限没开对------特别是 mariadb 默认禁用 root 远程登录,且新版本(10.4+)改用 authentication_string 字段存密码,老方法直接 update user set password=... 会失效甚至锁死账户。先确认你是本地连还是远程连:如果 Navicat 和 MariaDB 在同一台机器,Host 填 localhost 或 127.0.0.1 行为不同(前者走 socket,后者走 TCP),权限记录可能分开存检查实际生效的用户记录:SELECT User, Host, authentication_string FROM mysql.user WHERE User = 'root'; ------ 注意看 Host 列是 localhost、127.0.0.1 还是 %别信"重装/删库"这种方案:MariaDB 的权限表结构稳定,问题几乎都出在授权逻辑或认证插件上用GRANT重新授权比直接改表安全得多手动 UPDATE mysql.user 表风险高:字段名变化、加密方式不匹配、忘记 FLUSH PRIVILEGES 都会导致后续完全无法登录。用标准 SQL 授权既能绕过字段细节,又能自动适配当前认证机制。如果只想让 root 从本机连(推荐开发环境):GRANT ALL PRIVILEGES ON *.* TO 'root'@'localhost' IDENTIFIED BY '你的新密码' WITH GRANT OPTION;如果必须远程连(如腾讯云 CVM):GRANT ALL PRIVILEGES ON *.* TO 'root'@'%' IDENTIFIED BY '强密码' WITH GRANT OPTION;,然后立刻执行 FLUSH PRIVILEGES;注意:MariaDB 10.4+ 默认认证插件是 unix_socket 或 mysql_native_password,如果报错 Plugin 'auth_socket' is not loaded,加一句 ALTER USER 'root'@'%' IDENTIFIED VIA mysql_native_password USING PASSWORD('你的密码');skip-grant-tables 是最后手段,且必须严格收尾只有当你完全忘了 root 密码、又没其他管理账号时才启用它。但它会让整个数据库裸奔------任何能连上本地 socket/TCP 的人都能无密码操作所有库。编辑 /etc/my.cnf 或 /etc/mysql/mariadb.conf.d/50-server.cnf,在 mysqld 下加一行:skip-grant-tables重启服务:sudo systemctl restart mariadb(Linux)或 net stop mariadb && net start mariadb(Windows)此时可直接 mysql -u root 登录,但必须立刻执行:UPDATE mysql.user SET authentication_string = PASSWORD('新密码') WHERE User = 'root'; + FLUSH PRIVILEGES;最关键一步:删掉配置文件里的 skip-grant-tables,再重启一次服务------漏这步,数据库就永远不校验密码Navicat 连接设置里三个容易被忽略的细节即使 MariaDB 权限全开,Navicat 自身配置不对也会触发 1045。尤其在云服务器或 Docker 环境下,网络层和认证层容易错位。 稿定AI 拥有线稿上色优化、图片重绘、人物姿势检测、涂鸦完善等功能
相关推荐
DIY源码阁7 分钟前
JavaSwing航班订票管理系统 - MySQL版Cloud_Shy61842 分钟前
解读《Effective Python 3rd Edition》:从练气到老魔(第五章 Item 33 - 35)浪客灿心1 小时前
项目篇:模块设计与实现abcy0712131 小时前
python pandas csv异步后台清洗前端优先返回成功信息颜酱2 小时前
LangChain使用RAG 入门:让大模型读懂你的私有文档天天进步20152 小时前
Python全栈项目--校园智能宿舍管理系统测试员周周2 小时前
【AI测试智能体-面试】AI测试面试60题(附回答思路)用户8356290780513 小时前
使用 Python 操作 Word 评论和回复流星白龙3 小时前
【MySQL高阶】26.事务(1)cfm_29143 小时前
JVM类加载深入理解