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 拥有线稿上色优化、图片重绘、人物姿势检测、涂鸦完善等功能
相关推荐
92year14 小时前
用Google ADK从零搭一个能调工具的AI Agent:Python实操全过程woxihuan12345614 小时前
SQL删除数据时存在依赖关系_设置外键级联删除ON DELETE东风破13714 小时前
DM8达梦共享存储集群DSC搭建步骤雪碧聊技术14 小时前
当数据库字段数大于Java实体类属性数时,MyBatis还能映射成功吗?一文详解Jetev14 小时前
如何确定SQL字段是否为空_使用IS NULL与IS NOT NULL蛐蛐蛐15 小时前
昇腾910B4上安装新版本CANN的正确流程m0_7020365315 小时前
mysql如何处理不走索引的OR查询_使用UNION ALL优化重写代钦塔拉15 小时前
Qt4 vs Qt5 带参数信号槽的连接方式详解2401_8463395615 小时前
MySQL在云环境如何选择存储类型_SSD与高性能云盘配置建议2601_9577808416 小时前
Claude 4.6 对阵 GPT-5.4:2026 开发者大模型 API 选型深度解析