MySQL权限级别

背景
前几天遇到一个问题,给某业务用户赋权的时候,由于数据库比较多,为了方便,使用的是grant … on *.* 方式,后续想要收回某几个数据库的权限的时候,比如mysql,information_schema,performance_schema这几个数据库,无法单独revoke,只能revoke *.* 之后再单独授权,因为*.*是global级别的权限,而针对单个库的则是database级别的权限。

MySQL权限级别
MySQL 中的权限分为五个级别,分别如下:

1、Global Level:

Global Level 的权限控制又称为全局权限控制,所有权限信息都保存在mysql.user 表中。

Global Level 的所有权限都是针对整个mysqld 的,对所有的数据库下的所有表及所有字段都有效。

GRANT SELECT,UPDATE,DELETE,INSERT ON . TO ‘def’@’localhost’;

Global Level 主要有如下这些权限(以下为5.0.3以上版本拥有权限)

这里写图片描述

2、Database Level

Database Level 其作用域即为所指定整个数据库中的所有对象。

GRANT ALTER ON test.* TO ‘def’@’localhost’;

GRANT DROP ON * TO ‘def’@’localhost’;

Database Level 主要少了以下几个权限:CREATE USER,FILE,PROCESS,RELOAD,

REPLICATION CLIENT,REPLICATION SLAVE,

SHOW DATABASES,SHUTDOWN,SUPER 和USAGE 这几个权限,没有增加任何权限。

3、Table Level

Table Level 的权限作用范围是授权语句中所指定数据库的指定表。

GRANT INDEX ON test.t1 TO ‘abc’@’%.jianzhaoyang.com’;

Table Level 的权限由于其作用域仅限于某个特定的表,所以权限种类也比较少,仅有ALTER,CREATE,DELETE,DROP,INDEX,INSERT,SELECT UPDATE 这八种权限。

4、Column Level

Column Level 的权限作用范围就更小了,仅仅是某个表的指定的某个(或某些)列。

GRANT SELECT(id,value) ON test.t2 TO ‘abc’@’%.XXX’;

Column Level 级别的权限仅有 INSERT , SELECT 和 UPDATE 这三种。

5、Routine Level

Routine Level 主要针对的对象是procedure 和function 这两种对象,在授予Routine Level 权限的时候,需要指定数据库和相关对象

GRANT EXECUTE ON test.p1 to ‘abc’@’localhost’;

Routine Level 的权限主要只有EXECUTE 和ALTER ROUTINE 两种

  • 1
    点赞
  • 4
    收藏
    觉得还不错? 一键收藏
  • 0
    评论

“相关推荐”对你有帮助么?

  • 非常没帮助
  • 没帮助
  • 一般
  • 有帮助
  • 非常有帮助
提交
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值