如果mysql不支持远程连接,会出现提示:错误代码是1130,ERROR 1130: Host * is not allowed to connect to this MySQL server ,解决此问题有以下2个方法:
方法一
将需要被访问的mysql服务器的localhost值改成%
进入mysql的BIN目录
运行代码如下:
- --打开mysql数据库服务
- mysql -u root -p
- --打开mysql数据库文件
- mysql>use www.huayi1.cn/ mysql;
- --将mysql数据库中user表中user字段下的root用户的host值改为通配符%(默认是localhost)
- mysql>UPDATE user www.yibaoyule1.com SET host ='%' WHERE user = 'root';
- --修改之后再刷新一下权限
- mysql>flush privileges;
具体分析
1、在本机登入mysql后,更改“mysql”数据库里的“user”表里的“host”项,从”localhost”改为'%'。
代码如下:
mysql>
mysql>use mysql;
mysql>select 'host' from user where user='root';
#查看mysql库中的user表的host值(即可进行连接访问的主机/IP名称)
代码如下:
mysql>update user set host = '%' where user ='root';
#修改host值(以通配符%的内容增加主机/IP地址,当然也可以直接增加某个特定IP地址,如果执行update语句时出现ERROR 1062 (23000): Duplicate entry '%-root' for key 'PRIMARY' 错误,需要select host from user where user = 'root';
查看一下host是否已经有了%这个值,如果有了直接执行下面的flush privileges;即可)
代码如下:
mysql>flush privileges;
mysql>select www.chuangyed.com host,user from www.taohuayuan178.com user where user='root';
mysql>quit
方法二
如果你使用的是phpmyadmin我们可以登录phpmyadmin然后在权限管理中进入,这里会看到所有的用户了,你找到root用户点击修改,然后把域修改成%号即可了(注意,你必须是root权限用户登录哦,否则是不可以修改的)