MySQL中用户授权/删除授权的方法
本文章来给各位同学介绍在mysql中利用GRANT来给用户授权具体方法,同时也介绍了撤权并删除用户的命令,希望些方法对大家所有帮助.
用户授权方法,你可以通过发出GRANT语句增加新用户,代码如下:
- shell>mysql--user=rootmysql
- mysql>GRANTALLPRIVILEGESON*.*TOmonty@localhost
- IDENTIFIEDBY'something'WITHGRANTOPTION;
- mysql>GRANTALLPRIVILEGESON*.*TOmonty@"%"
- IDENTIFIEDBY'something'WITHGRANTOPTION;
- mysql>GRANTRELOAD,PROCESSON*.*TOadmin@localhost;
- mysql>GRANTUSAGEON*.*TOdummy@localhost; //phpfensi.com
这些GRANT语句安装3个新用户
授权:命令:GRANT privileges ON databasename.tablename TO 'username'@'host'
说明:privileges - 用户的操作权限,如SELECT , INSERT , UPDATE 等(详细列表见该文最后面).如果要授予所的权限则使用ALL.;databasename - 数据库名,tablename-表名,如果要授予该用户对所有数据库和表的相应操作权限则可用*表示, 如*.*.
例子,代码如下:
GRANT SELECT, INSERT ON test.user TO 'pig'@'%';
GRANT ALL ON *.* TO 'pig'@'%';
注意:用以上命令授权的用户不能给其它用户授权,如果想让该用户可以授权,用以下命令,代码如下:
GRANT privileges ON databasename.tablename TO 'username'@'host' WITH GRANT OPTION;
设置与更改用户密码
命令,代码如下:
SET PASSWORD FOR 'username'@'host' = PASSWORD('newpassword');
如果是当前登陆用户用如下代码:
SET PASSWORD = PASSWORD("newpassword");
例子,代码如下:
SET PASSWORD FOR 'pig'@'%' = PASSWORD("123456");
撤权并删除用户:要取消一个用户的权限,使用REVOKE语句,REVOKE的语法非常类似于GRANT语句,除了TO用FROM取代并且没有INDETIFED BY和WITH GRANT OPTION子句,代码如下:
REVOKE privileges (columns) ON what FROM user
user部分必须匹配原来 GRANT语句的你想撤权的用户的user部分,privileges部分不需匹配,你可以用GRANT语句授权,然后用REVOKE语句只撤销部分权限.
REVOKE语句只删除权限,而不删除用户,即使你撤销了所有权限,在user表中的用户记录依然保留,这意味着用户仍然可以连接服务器,要完全删除一个用户,你必须用一条Delete语句明确从user表中删除用户记录,代码如下:
- %mysql-urootmysqlmysql>DeleteFROMuser->WhereUser="user_name"andHost="host_name";mysql>FLUSHPRIVILEGES;
Delete语句删除用户记录,而FLUSH语句告诉服务器重载授权表,当你使用GRANT和REVOKE语句时,表自动重载,而你直接修改授权表时不是.
热门评论