mysql> grant 权限1,权限2,…权限n on 数据库名称.表名称 to 用户名@用户地址 identified by "链接口令";
看上去像这样:html
GRANT privileges (columns) ON what TO user IDENTIFIED BY "password" WITH GRANT OPTION当权限1,权限2,…权限n被all privileges或者all代替,表示赋予用户所有权限。
当数据库名称.表名称被*.*代替,表示赋予用户操做服务器上全部数据库全部表的权限。
用户地址能够是localhost,也能够是ip地址、机器名字、域名。也能够用’%'表示从任何地址链接。
‘链接口令’不能为空,不然建立失败。
要使用该语句,你须要填写下列部分:
privileges
授予用户的权限,下表列出可用于GRANT语句的权限指定符:mysql
ALTER 修改表和索引
CREATE 建立数据库和表
DELETE 删除表中已有的记录
DROP 抛弃(删除)数据库和表
INDEX 建立或抛弃索引
INSERT 向表中插入新行
REFERENCE 未用
SELECT 检索表中的记录
UPDATE 修改现存表记录
FILE 读或写服务器上的文件
PROCESS 查看服务器中执行的线程信息或杀死线程
RELOAD 重载受权表或清空日志、主机缓存或表缓存
SHUTDOWN 关闭服务器
ALL 全部;ALL PRIVILEGES同义词
USAGE 特殊的“无权限”权限
上表显示在第一组的权限指定符适用于数据库、表和列,第二组数管理权限。通常,这些被相对严格地受权,由于它们容许用户影响服务器的操做。第三组权限特殊,ALL意味着“全部权限”,UASGE意味着无权限,即建立用户,但不授予权限。sql
columns数据库
权限运用的列,它是可选的,而且你只能设置列特定的权限。若是命令有多于一个列,应该用逗号分开它们。缓存
what安全
权限运用的级别。权限能够是全局的(适用于全部数据库和全部表)、特定数据库(适用于一个数据库中的全部表)或特定表的。能够经过指定一个columns字句是权限是列特定的。服务器
useride
权限授予的用户,它由一个用户名和主机名组成。在MySQL中,你不只指定谁能链接,还有从哪里链接。这容许你让两个同名用户从不一样地方链接。MySQL让你区分他们,并彼此独立地赋予权限。函数
MySQL中的一个用户名就是你链接服务器时指定的用户名,该名字没必要与你的Unix登陆名或Windows名联系起来。缺省地,若是你不明确指定一个名字,客户程序将使用你的登陆名做为MySQL用户名。这只是一个约定。你能够在受权表中将该名字改成nobody,而后以nobody链接执行须要超级用户权限的操做。post
password
赋予用户的口令,它是可选的。若是你对新用户没有指定IDENTIFIED BY子句,该用户不赋给口令(不安全)。对现有用户,任何你指定的口令将代替老口令。若是你不指定口令,老口令保持不变,当你用IDENTIFIED BY时,口令字符串用改用口令的字面含义,GRANT将为你编码口令,不要象你用SET PASSWORD 那样使用password()函数。
WITH GRANT OPTION子句是可选的。若是你包含它,用户能够授予权限经过GRANT语句受权给其它用户。你能够用该子句给与其它用户受权的能力。
用户名、口令、数据库和表名在受权表记录中是大小写敏感的,主机名和列名不是。
mysql> grant select,insert,update,delete,create,drop on vtdc.employee to joe@10.163.225.87 identified by ‘123′;
给来自10.163.225.87的用户joe分配可对数据库vtdc的employee表进行select,insert,update,delete,create,drop等操做的权限,并设定口令为123。
mysql> grant all privileges on vtdc.* to joe@10.163.225.87 identified by ‘123′;
给来自10.163.225.87的用户joe分配可对数据库vtdc全部表进行全部操做的权限,并设定口令为123。
mysql> grant all privileges on *.* to joe@10.163.225.87 identified by ‘123′;
给来自10.163.225.87的用户joe分配可对全部数据库的全部表进行全部操做的权限,并设定口令为123。
mysql> grant all privileges on *.* to joe@localhost identified by ‘123′;
给本机用户joe分配可对全部数据库的全部表进行全部操做的权限,并设定口令为123。
flush privileges;