当我们忘记Mysql的登陆密码的时候。
可以输入vi /etc/my.cnf 修改Mysql的配置。
在[mysqld]行下,输入 skip-grant-tables 保存退出,
输入 service mysqld restart 重启mysql
这里写图片描述
这里写图片描述

这样就可以无密码登陆mysql了,登陆之后,输入:

use mysql;
update user set password=password('123456') where user = 'root';
flush privileges;

这里写图片描述

然后再进入 vi /etc/my.cnf 配置文件,将刚才加上去的skip-grant-tables语句删除,保存退出。
重启一下mysql,就可以用新的密码登陆了。

当我需要远程登陆mysql的时候,有时候会发现用户没有远程登陆的权限。
这时候就要修改登录权限,将用户只允许本地登录改成允许远程登录
1、改表法。
在localhost的那台电脑,登入mysql后,更改 “mysql” 数据库里的 “user” 表里的 “host” 项,从”localhost”改称”%”

mysql -u root -pvmwaremysql>use mysql;
mysql>update user set host = '%' where user = 'root';
mysql>select host, user from user;

2、授权法。
(1)例如,你想myuser使用mypassword从任何主机连接到mysql服务器的话。

GRANT ALL PRIVILEGES ON *.* TO 'myuser'@'%' IDENTIFIED BY 'mypassword' WITH GRANT OPTION;
FLUSH   PRIVILEGES;

(2)如果你想允许用户myuser从ip为192.168.1.6的主机连接到mysql服务器,并使用mypassword作为密码

GRANT ALL PRIVILEGES ON *.* TO 'myuser'@'192.168.1.3' IDENTIFIED BY 'mypassword'  WITH GRANT OPTION;
FLUSH   PRIVILEGES;

(3)如果你想允许用户myuser从ip为192.168.1.6的主机连接到mysql服务器的dk数据库,并使用mypassword作为密码

GRANT ALL PRIVILEGES ON dk.* TO 'myuser'@'192.168.1.3' IDENTIFIED BY 'mypassword' WITH GRANT OPTION;
FLUSH   PRIVILEGES;
Logo

更多推荐