使用Navicat连接MySql8.0版本远程数据库

       在云服务器上搭载MySql数据库,如果想用本地Navicat操作数据库的话不是一件难事,在网上一搜一大片,但是仔细去看现在的教程基本上都是8.0一下版本的数据库,如果将同样的操作放在8.0上肯定是不行(当然不是完全不行,有些步骤还是可以的)。

注意:下面的操作完全是基于MySql8.0的

1.修改密码

当我们安装完数据库的时候,系统会强制我们修改密码,就是你的任何命令都会显示如图所示:

使用Navicat连接MySql8.0版本远程数据库

所以呢就必须要修改密码了,这次呢就不能使用以前的修改方式了:

set password for 'root'@'localhost'=password('NewPassword');  (错的

而是要用:

alter user user() identified by "你的密码";(对的

2.远程连接

现在使用Navicat进行连接肯定是不行,因为你的数据库还需要进行很多配置。

(1).先查看3306端口(MySql默认3306端口)

使用Navicat连接MySql8.0版本远程数据库

说明3306接口并没有固定监听某一个IP地址。

(2).进入MySql命令行界面输入

use mysql;
select user, host from user;

你会发现:

使用Navicat连接MySql8.0版本远程数据库

然后修改root对应的host:

执行  update user set host = '%' where user = 'root'; 

再次执行select user,host from user;

使用Navicat连接MySql8.0版本远程数据库

修改成功。

(3).权限修改

这最重要的一步,目的就是赋予所有IP访问数据库的权限。

GRANT ALL PRIVILEGES ON *.* TO 用户名@'%' IDENTIFIED BY '你的密码' WITH GRANT OPTION;(错的

这样做是不可以的。

 应该为:

ALTER USER 'aaa(用户名)'@'%' IDENTIFIED WITH mysql_native_password BY 'bbb(密码)';(对的

%代表所有IP,这句话代表允许所有IP以用户名:aaa和密码:bbb的方式访问数据库。当然要写你自己的用户名和密码了。

好了,这样就完成了。下面进行Navicat连接就可以了。

使用Navicat连接MySql8.0版本远程数据库