做为mysql数据库管理员管理用户账户,是一件很重要的事,指出哪个用户可以连接服务器,从哪里连接,连接后能做什么。mysql从3.22
大纲
一、前言
二、创建用户并授权
三、grant语句的种类
四、撤权并删除用户
推荐阅读:
mysql用户管理
mysql用户工具
一、前言
做为mysql数据库管理员管理用户账户,是一件很重要的事,指出哪个用户可以连接服务器,从哪里连接,连接后能做什么。mysql从3.22.11开始引入两个语句来做这件事,grant语句创建mysql用户并指定其权限,而revoke语句删除权限。create和revoke语句影响4个表,
user 能连接服务器的用户以及他们拥有的任何全局权限
db 数据库级权限
tables_priv 表级权限
columns_priv 列级权限
还有第5个授权表host,但它不受grant和revoke的影响,下面我们看一下mysql数据库中的所有表,
1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
21
22
23
24
25
26
27
28
29
30
31
32
mysql> use mysql;
database changed
mysql> show tables;
+---------------------------+
| tables_in_mysql |
+---------------------------+
| columns_priv |
| db |
| event |
| func |
| general_log |
| help_category |
| help_keyword |
| help_relation |
| help_topic |
| host |
| ndb_binlog_index |
| plugin |
| proc |
| procs_priv |
| proxies_priv |
| servers |
| slow_log |
| tables_priv |
| time_zone |
| time_zone_leap_second |
| time_zone_name |
| time_zone_transition |
| time_zone_transition_type |
| user |
+---------------------------+
24 rows in set (0.00 sec)
当你对一个用户发出一条grant语句时,在user表中为该用户创建一条记录。如果语句指定任何全局权限(管理权限或适用于所有数据库的权限),这些也记录在user表中。如果你指定数据库、表和列级权限,他们被分别记录在db、tables_priv和columns_priv表中。
二、创建用户并授权
1.grant 语句的用法
1
2
3
4
5
6
7
8
9
10
11
mysql> ? grant
name: 'grant'
description:
syntax:
grant
priv_type [(column_list)]
[, priv_type [(column_list)]] ...
on [object_type] priv_level
to user_specification [, user_specification] ...
[require {none | ssl_option [[and] ssl_option] ...}]
[with with_option ...]
grant语句的语法看上去像这样,
注:红颜色标识出来的,都是可以定义的,下面我们来一个一个说明!
2.权限分类 (privileges)
第一组:指定符适用于数据库、表和列
alter 修改表和索引
create 创建数据库和表
delete 删除表中已有的记录
drop 删除数据库和表
index 创建或抛弃索引
insert 向表中插入新行
reference 未用
select 检索表中的记录
update 修改现存表记录
第二组:指定数据库数管理权限
file 读或写服务器上的文件
process 查看服务器中执行的线程信息或杀死线程
reload 重载授权表或清空日志、主机缓存或表缓存
shutdown 关闭服务器
第三组权限特殊:all意味着“所有权限”,uasge意味着无权限,即创建用户,但不授予权限
all 所有;all privileges“所有权限”
usage 特殊的“无权限”权限
3.columns
权限运用的列,它是可选的,并且你只能设置列特定的权限。如果命令有多于一个列,应该用逗号分开它们。
4.what
权限运用的级别。权限可以是全局的(适用于所有数据库和所有表)、特定数据库(适用于一个数据库中的所有表)或特定表的。可以通过指定一个columns字句是权限是列特定的。
5.user
权限授予的用户,它由一个用户名和主机名组成。在mysql中,你不仅指定谁能连接,还有从哪里连接。这允许你让两个同名用户从不同地方连接。mysql让你区分他们,并彼此独立地赋予权限。
mysql中的一个用户名就是你连接服务器时指定的用户名,,该名字不必与你的unix登录名或windows名联系起来。缺省地,如果你不明确指定一个名字,客户程序将使用你的登录名作为mysql用户名。这只是一个约定。你可以在授权表中将该名字改为nobody,然后以nobody连接执行需要超级用户权限的操作。
6.password
赋予用户的口令,它是可选的。如果你对新用户没有指定identified by子句,该用户不赋给口令(不安全)。对现有用户,任何你指定的口令将代替老口令。如果你不指定口令,老口令保持不变,当你用identified by时,口令字符串用改用口令的字面含义,grant将为你编码口令,不要象你用set password 那样使用password()函数。
7.with grant option子句是可选的。如果你包含它,用户可以授予权限通过grant语句授权给其它用户。你可以用该子句给与其它用户授权的能力。
注:用户名、口令、数据库和表名在授权表记录中是大小写敏感的,而主机名和列名不是。
三、grant语句的种类
一般地,你可以通过询问几个简单的问题来识别grant语句的种类:
谁能连接,从那儿连接?
用户应该有什么级别的权限,他们适用于什么?
用户应该允许管理权限吗?
1.谁能连接,从那儿连接?
(1).你可以允许一个用户从特定的或一系列主机连接。
1
grant all on db.* to free@localhost identified by 123456;
说明:db.*意思是“db数据库的所有表
(2).你可能有一个经常外出并需要能从任何主机连接的用户free。在这种情况下,你可以允许他无论从哪里连接:
1
grant all on db.* to free@% identified by 123456;
1
grant all on db.* to mary@%.free.net identified by 123456;