在同班大神的提点下,终于知道了怎样开启MySQL远程连接。在此小记,另外我使用的是Windows系统,不是Linux。

▍打开MYSQL

1、打开命令提示符:可以通过在搜索“命令提示符”找到它,然后打开

或者按下【Win+R】,在弹出的运行窗口中输入【cmd】,然后按【确认】键打开。打开后如下图所示:

在窗口中输入:【net start mysql】,然后按下【Enter】键。如下图,这时MYSQL就启动了:

MySQL启动之后输入【mysql -u MySQL用户名 -p】,这里的用户名一般就是【root】,输入后按下【Enter】。此时在下一行会提示【Enter password:】,这个时候输入与上面的用户名所匹配的密码,一般是【123456】,输入后按下【Enter】,就顺利进入MySQL命令窗口了。

▍创建远程连接用户

创建格式如下:

GRANT 【权限内容】 ON 【库名】.【表名】 TO '【用户名】'@'【IP地址】' IDENTIFIED BY '【密码】' WITH GRANT OPTION;

示例:赋予用户名为【MAO】,密码为【MIAOMIAO】的用户可以在任意设备上操作所有数据库表的权限

GRANT ALL PRIVILEGES ON *.* TO 'MAO'@'%' IDENTIFIED BY 'MIAOMIAO' WITH GRANT OPTION;
解释一下每个地方该怎么填:

【权限内容】

赋予的权限    写法
所有权限(增、删、改、查)    all privileges
增    insert
删    delete
改    update
查    select
 

【库名】.【表名】

被赋予权限的库表    写法
全部库表    *.*
某个库中的全部表(如eshop库中的所有表)    eshop.*
某个库中的单个表(如eshop库中的user表)    eshop.user
 

【用户名】和【密码】可自行设置,只要自己能记住就行了。

【IP地址】

可连接该数据库的设备    写法
所有设备    %
特定设备:填写这些设备的IP地址    例:192.168.83.1
 

【小结】我配置的时候,到这一步就已经可以完成远程连接了。但是在参考其它关于这一问题的文章时,好多博主同时提到了一些后续步骤,虽然不知道是否真的有这个必要,但是还是附加在后面,以防万一。

▍使命令立刻执行

FLUSH PRIVILEGES;
 

▍查询数据库用户

SELECT DISTINCT CONCAT('User: ''',user,'''@''',host,''';') AS query FROM mysql.user; 
 

▍如果是Linux系统:修改配置文件

打开vim /etc/mysql/my.cnf
将bind-address = 127.0.0.1
设置成bind-address = 0.0.0.0(设备地址)