Navicat连接MySQL数据库提示:1130 - Host 'xxx' is not allowed to connect to this MySQL server 原创 阁主 2023-01-01 16:23:13 阅读 919 次 评论 0 条 摘要:在局域网搭建了一台MySQL服务器,但是在使用笔记本无法连接上,错误信息和解决方法在正文。 ## 错误信息 Navicat连接提示:1130 - Host 'xxx' is not allowed to connect to this MySQL server ![](https://www.mainblog.cn/zb_users/upload/2023/01/202301011521295958723.png) ## 错误原因 mysql未开启mysql远程访问权限导致。 ## 解决方法 登录到mysql: mysql -uroot -proot 查看user表 ```sql # 使用数据库mysql use mysql; # 查看主机和用户 select host, user from user; ``` ![](https://www.mainblog.cn/zb_users/upload/2023/01/202301011636172901916.png) 表中host、user字段标识了可以访问数据库的主机和用户。例如上面的数据就表示只能本地主机通过root用户访问。为了让数据库支持远程主机访问,有两种方法可以开启远程访问功能,这里建议使用第一种 **第一种(改表法):** 修改host字段的值,将localhost修改成需要远程连接数据库的ip地址。或者直接修改成%。(修改成%表示,所有主机都可以通过root用户访问数据库)这里就直接修改成%。命令如下: ``update user set host = '%' where user = 'root';`` 再次查看user表, 修改成功,重启数据库或者输入命令FLUSH PRIVILEGES(重新加载权限表);测试再次远程连接数据库成功。 ![](https://www.mainblog.cn/zb_users/upload/2023/01/202301011653421872365.png) **第二种(授权法):** root使用密码root从任何主机连接到mysql服务器,命令如下: ``GRANT ALL PRIVILEGES ON *.* TO 'root'@'%' IDENTIFIED BY 'root' WITH GRANT OPTION;`` 允许用户user从ip为192.168.1.30的主机连接到mysql服务器,并使用user作为密码: ``GRANT ALL PRIVILEGES ON *.* TO 'root'@'192.168.1.30' IDENTIFIED BY 'mypassword' WITH GRANT OPTION; `` 重启数据库或者输入命令FLUSH PRIVILEGES(重新加载权限表) ## 注意: 记得执行修改记录后需要使用命令:FLUSH PRIVILEGES进行刷新权限操作。 本文地址:https://www.mainblog.cn/289.html 版权声明:本文为原创文章,版权归 阁主 所有,欢迎分享本文,转载请保留出处! 免责申明:有些内容源于网络,没能联系到作者。如侵犯到你的权益请告知,我们会尽快删除相关内容。 PREVIOUS:PyCharm常用快捷键 NEXT:Python对列表list求交集并集差集补集 文章导航