数据库服务器通常包含了非常重要的数据,可以通过访问控制来确保这些数据的安全,而 DCL 就是解决这一问题的,它可以为指定的用户授予访问权限或者从指定用户处召回指定的权限。DCL 对数据库管理员来说非常重要,因为用户权限的管理关系到数据库的安全。简单的说,我们可以通过 DCL 允许受信任的用户访问数据库,阻止不受信任的用户访问数据库,同时还可以通过 DCL 将每个访问者的的权限最小化(让访问者的权限刚刚够用)。
我们可以使用下面的 SQL 来创建一个用户并为其指定访问口令。
create user 'wangdachui'@'%' identified by 'Wang.618';
上面的 SQL 创建了名为 wangdachui 的用户,它的访问口令是 Wang.618,该用户可以从任意主机访问数据库服务器,因为 @ 后面使用了可以表示任意多个字符的通配符 %。如果要限制 wangdachui 这个用户只能从 192.168.0.x 这个网段的主机访问数据库服务器,可以按照下面的方式来修改 SQL 语句。
drop user if exists 'wangdachui'@'%';
create user 'wangdachui'@'192.168.0.%' identified by 'Wang.618';
此时,如果我们使用 wangdachui 这个账号访问数据库服务器,我们几乎不能做任何操作,因为该账号没有任何操作权限。
我们用下面的语句为 wangdachui 授予查询 school 数据库学院表(tb_college
)的权限。
grant select on `school`.`tb_college` to 'wangdachui'@'192.168.0.%';
我们也可以让 wangdachui 对 school 数据库的所有对象都具有查询权限,代码如下所示。
grant select on `school`.* to 'wangdachui'@'192.168.0.%';
如果我们希望 wangdachui 还有 insert、delete 和 update 权限,可以使用下面的方式进行操作。
grant insert, delete, update on `school`.* to 'wangdachui'@'192.168.0.%';
如果我们还想授予 wangdachui 执行 DDL 的权限,可以使用如下所示的 SQL。
grant create, drop, alter on `school`.* to 'wangdachui'@'192.168.0.%';
如果我们希望 wangdachui 账号对所有数据库的所有对象都具备所有的操作权限,可以执行如下所示的操作,但是一般情况下,我们不会这样做,因为我们之前说过,权限刚刚够用就行,一个普通的账号不应该拥有这么大的权限。
grant all privileges on *.* to 'wangdachui'@'192.168.0.%';
如果要召回 wangdachui 对 school 数据库的 insert、delete 和 update 权限,可以使用下面的操作。
revoke insert, delete, update on `school`.* from 'wangdachui'@'192.168.0.%';
如果要召回所有的权限,可以按照如下所示的方式进行操作。
revoke all privileges on *.* from 'wangdachui'@'192.168.0.%';
需要说明的是,由于数据库可能会缓存用户的权限,可以在授予或召回权限后执行下面的语句使新的权限即时生效。
flush privileges;