如:
mysql -h 19216802 -P 3306 -u root -p123
远程数据库(19216802),端口3306,用户名为:root,密码:123三种解决方法:
1、改表法。可能是你的帐号不允许从远程登陆,只能在localhost。这个时候只要在localhost的那台电脑,登入mysql后,更改
"mysql" 数据库里的 "user" 表里的 "host" 项,从"localhost"改称"%"
mysql -u root -pvmware
mysql>use mysql;
mysql>update user set host = '%' where user =
'root';
mysql>select host, user from user;
2、授权法。例如,你想myuser使用mypassword从任何主机连接到mysql服务器的话。
GRANT ALL PRIVILEGES ON TO 'myuser'@'%'IDENTIFIED BY 'mypassword' WITH
GRANT OPTION;
如果你想允许用户myuser从ip为19216816的主机连接到mysql服务器,并使用mypassword作为密码
GRANT
ALL PRIVILEGES ON TO 'myuser'@'19216813'IDENTIFIED BY 'mypassword' WITH
GRANT OPTION;
我用的第一个方法,刚开始发现不行,在网上查了一下,少执行一个语句 mysql>FLUSH RIVILEGES
使修改生效,就可以了
第三种方法:
在安装mysql的机器上运行:
1、d:\mysql\bin\>mysql -h localhost -u root
//这样应该可以进入MySQL服务器
2、mysql>GRANT ALL PRIVILEGES ON TO 'root'@'%'WITH GRANT OPTION
//赋予任何主机访问数据的权限
3、mysql>FLUSH PRIVILEGES
//修改生效
4、mysql>EXIT
//退出MySQL服务器
这样就可以在其它任何的主机上以root身份登录了。
之上是找的资源,实际情况是你远程额服务器,如果是用服务器的话,安装的有PHPMYADMIN, 那么将省去很多代码。Navicat是一个强大的MySQL数据库管理和开发工具。 Navicat为专业开发者提供了一套强大的足够尖端的工具,但它对于新用户仍然很易于学习。使用了极好的图形用户界面。在使用的过程中当连接远程mysql数据库时,连接总是无法建立,后来发现被连接的数据库需要授权欲连接的navicat所在机器ip地址。 navicat装在机器A上,ip地址为ipa。mysql数据库装在机器B上,ip地址为ipb。 1、进入机器B中mysql数据库的命令行,输入grant all on to 'root'@'ipa' identified by 'password'; 其中ipa为被授权机器A的ip地址,password为机器B中mysql数据库的密码。 2、在机器A的navicat中,建立新的连接,输入机器B的ip地址,机器B中mysql数据库的port,username,password,然后test connection,成功则可。若仍不成功,检查机器B中mysql数据库的配置,包括端口是否匹配,服务是否开启等等。Navicat是一个强大的MySQL数据库管理和开发工具。 Navicat为专业开发者提供了一套强大的足够尖端的工具,但它对于新用户仍然很易于学习。使用了极好的图形用户界面。在使用的过程中当连接远程mysql数据库时,连接总是无法建立,后来发现被连接的数据库需要授权欲连接的navicat所在机器ip地址。 navicat装在机器A上,ip地址为ipa。mysql数据库装在机器B上,ip地址为ipb。 1、进入机器B中mysql数据库的命令行,输入grant all on to 'root'@'ipa' identified by 'password'; 其中ipa为被授权机器A的ip地址,password为机器B中mysql数据库的密码。 2、在机器A的navicat中,建立新的连接,输入机器B的ip地址,机器B中mysql数据库的port,username,password,然后test connection,成功则可。若仍不成功,检查机器B中mysql数据库的配置,包括端口是否匹配,服务是否开启等等。
首先MySQL只允许本地连接登录,如果要远程登录需要修改数据库中user表 中的host内容改成%或指定ip。%是任意的IP都可以远程连接上的。完成这个修改就可以远程连接上了,不过值得注意的是:需要给服务器数据库登录名root账号设置一个密码,不然无法远程连接。如果还不能连接上,可看一下防火墙是否允许了3306商品访问
先看看我改成%,让所有的ip可以连接到,如图下:
/opt/lampp/bin/mysql -uroot -p 进入数据库 *** 作,这里是使用了root登录数据库,root没有密码可直接mysql可以进去
看到user表中host已经被修改成了,可以通过sql语句修改host的内容。这样就可以远程连接上了
UPDATE user SET host='%' WHERE user='root';
欢迎分享,转载请注明来源:内存溢出
评论列表(0条)