mysql用户授权之GRANT ALL PRIVILEGES用法举例

发布时间:2019-09-26编辑:脚本学堂
本文详细介绍了mysql数据库中用户授权命令GRANT ALL PRIVILEGES的用法,有理论有实例,有需要的朋友参考下。

 
1,改表法。
如果帐号不允许从远程登陆,只能在localhost。
此时只要在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,授权法。
例如,myuser使用mypassword从任何主机连接到mysql服务器的话。
 

复制代码 代码示例:
GRANT ALL PRIVILEGES ON *.* TO 'myuser'@'%' IDENTIFIED BY 'mypassword' WITH
      GRANT OPTION; 
FLUSH   PRIVILEGES;

允许用户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;  

允许用户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;  

注意,授权后必须FLUSH PRIVILEGES;否则无法立即生效。 
 
另外一种方法.
在安装mysql的机器上运行:
1、

复制代码 代码示例:
d:mysqlbin>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身份登录啦!
 
其它:
 

复制代码 代码示例:
mysql> grant all privileges on *.* to 'energy_pf'@'192.168.2.65' identified by 'energy_pf' with grant option;
Query OK, 0 rows affected (0.00 sec)
 
mysql> plush privileges;
 

允许用户energy_pf从ip为192.168.2.65的主机连接到mysql服务器的任意数据库(*.*),并使用energy_pf作为密码。