手机
当前位置:查字典教程网 >编程开发 >php教程 >MySQL授权问题总结
MySQL授权问题总结
摘要:我用localhost的root帐号不能连最后请教DBA组新建用户搞定!现弄些受权用户的资料以备不时之需授权表使用举例grant用于给增加用...

我用localhost的root帐号不能连最后请教DBA组新建用户搞定!

现弄些受权用户的资料以备不时之需

授权表使用举例

grant用于给增加用户和创建权限,revoke用于删除用户权限。

下面是一些用grant增加用户和创建权限的例子:

mysql>grantallprivilegeson*.*totest@localhostidentifiedby'test'withgrantoption;

这句增加一个本地具有所有权限的test用户(超级用户),密码是test。ON子句中的*.*意味着"所有数据库、所有表"。withgrantoption表示它具有grant权限。

mysql>grantselect,insert,update,delete,create,dropprivilegesontest.*totest1@'192.168.1.0/255.255.255.0'identifiedby'test';

这句是增加了一个test1用户,口令是test,但是它只能从C类子网192.168.1连接,对test库有select,insert,update,delete,create,drop操作权限。

用grant语句创建权限是不需要再手工刷新授权表的,因为它已经自动刷新了。

给用户创建权限还可以通过直接修改授权表:

mysql>insertintouser

values("localhost","test",password("test"),"Y","Y","Y","Y","Y","Y","Y","Y","Y","Y","Y","Y","Y","Y");

mysql>flushprivileges;

这两句和上面第一句grant的效果是一样的,也是增加了一个本地的test超级用户。我们看到用grant方便多了,而且还不需flushprivileges。

mysql>insertintouser(host,user,password)values("192.168.1.0/255.255.255.0","test1",PASSWORD("test"));mysql>insertintodbvalues("192.168.1.0/255.255.255.0","test","test1","Y","Y","Y","Y","Y","Y","N","N","N","N")mysql>flushprivileges;

这三句和上面第二句grant的效果也是一样的,也是增加了一个只能从C类子网192.168.1连接,对test库有select,insert,update,delete,create,drop操作权限的test1用户,口令是test。要取消一个用户的权限,使用revoke语句。revoke的语法非常类似于grant语句,除了to用from取代并且没有identifiedby和withgrantoption子句,下面是用revoke删除用户权限的例子:

mysql>revokeallontest.*fromtest1@'192.168.1.0/255.255.255.0';

这句revoke就撤消了上面第二句grant创建的权限,但是test1用户并没有被删除,必须手工从user表删除:

mysql>deletefromuserwhereuser='test1';

mysql>flushprivileges;

这样,test1用户就彻底删除了。

这些只是MySQL授权表的简单使用,更多详细的资料请见MySQL提供的手册。

【MySQL授权问题总结】相关文章:

PHP4 与 MySQL 数据库操作函数详解

PHP+MYSQL的文章管理系统(一)

数据库相关问题

5.PHP的其他功能

PHP安装问题

PHP浮点数精度问题汇总

php中smarty实现多模版网站的方法

初探PHP5

编译问题

PHP查找与搜索数组元素方法总结

精品推荐
分类导航