GRANT
GRANT
Name
GRANT
Description
GRANT 命令有如下功能:
- 将指定的权限授予某用户或角色。
- 将指定角色授予某用户。
注意:
2.0 及之后版本支持"将指定角色授予用户"
GRANT privilege_list ON priv_level TO user_identity [ROLE role_name]
GRANT privilege_list ON RESOURCE resource_name TO user_identity [ROLE role_name]
GRANT role_list TO user_identity
GRANT privilege_list ON WORKLOAD GROUP workload_group_name TO user_identity [ROLE role_name]
privilege_list 是需要赋予的权限列表,以逗号分隔。当前 Doris 支持如下权限:
NODE_PRIV:集群节点操作权限,包括节点上下线等操作。同时拥有 Grant_priv 和 Node_priv 的用户,可以将该权限赋予其他用户。
ADMIN_PRIV:除 NODE_PRIV 以外的所有权限。
GRANT_PRIV: 操作权限的权限。包括创建删除用户、角色,授权和撤权,设置密码等。
SELECT_PRIV:对指定的库或表的读取权限
LOAD_PRIV:对指定的库或表的导入权限
ALTER_PRIV:对指定的库或表的schema变更权限
CREATE_PRIV:对指定的库或表的创建权限
DROP_PRIV:对指定的库或表的删除权限
USAGE_PRIV: 对指定资源的使用权限和workload group权限
SHOW_VIEW_PRIV: 查看`view`创建语句的权限(从2.0.3版本开始,`SELECT_PRIV`和`LOAD_PRIV`权限不能`SHOW CREATE TABLE view_name`,拥有`CREATE_PRIV`,`ALTER_PRIV`,`DROP_PRIV`,`SHOW_VIEW_PRIV`权限项中的任何一个,有权`SHOW CREATE TABLE view_name`)
旧版权限中的 ALL 和 READ_WRITE 会被转换成:SELECT_PRIV,LOAD_PRIV,ALTER_PRIV,CREATE_PRIV,DROP_PRIV;
READ_ONLY 会被转换为 SELECT_PRIV。
权限分类:
1. 节点权限:NODE_PRIV
2. 库表权限:SELECT_PRIV,LOAD_PRIV,ALTER_PRIV,CREATE_PRIV,DROP_PRIV
3. 资源权限和 workload group 权限:USAGE_PRIV
priv_level 支持以下四种形式:
1. *.*.* 权限可以应用于所有 catalog 及其中的所有库表
2. catalog_name.*.* 权限可以应用于指定 catalog 中的所有库表
3. catalog_name.db.* 权限可以应用于指定库下的所有表
4. catalog_name.db.tbl 权限可以应用于指定库下的指定表
这里指定的 catalog_name 或库或表可以是不存在的库和表。
resource_name 支持以下两种形式:
1. * 权限应用于所有资源
2. resource 权限应用于指定资源
这里指定的资源可以是不存在的资源。另外,这里的资源请跟外部表区分开,有使用外部表的情况请都使用 catalog 作为替代。
workloadgroup_name 可指定 workload group 名,支持 %
和`匹配符,
%可匹配任意字符串,
_`匹配任意单个字符。
user_identity:
这里的 user_identity 语法同 CREATE USER。且必须为使用 CREATE USER 创建过的 user_identity。user_identity 中的host可以是域名,如果是域名的话,权限的生效时间可能会有1分钟左右的延迟。
也可以将权限赋予指定的 ROLE,如果指定的 ROLE 不存在,则会自动创建。
role_list 是需要赋予的角色列表,以逗号分隔,指定的角色必须存在。
Example
授予所有 catalog 和库表的权限给用户
GRANT SELECT_PRIV ON *.*.* TO 'jack'@'%';
授予指定库表的权限给用户
GRANT SELECT_PRIV,ALTER_PRIV,LOAD_PRIV ON ctl1.db1.tbl1 TO 'jack'@'192.8.%';
授予指定库表的权限给角色
GRANT LOAD_PRIV ON ctl1.db1.* TO ROLE 'my_role';
授予所有资源的使用权限给用户
GRANT USAGE_PRIV ON RESOURCE * TO 'jack'@'%';
授予指定资源的使用权限给用户
GRANT USAGE_PRIV ON RESOURCE 'spark_resource' TO 'jack'@'%';
授予指定资源的使用权限给角色
GRANT USAGE_PRIV ON RESOURCE 'spark_resource' TO ROLE 'my_role';
将指定角色授予某用户
```sql
GRANT 'role1','role2' TO 'jack'@'%';
```提示该功能自 Apache Doris 2.0 版本起支持
将指定 workload group‘g1’授予用户 jack
GRANT USAGE_PRIV ON WORKLOAD GROUP 'g1' TO 'jack'@'%';
匹配所有 workload group 授予用户 jack
GRANT USAGE_PRIV ON WORKLOAD GROUP '%' TO 'jack'@'%';
将指定 workload group‘g1’授予角色 my_role
GRANT USAGE_PRIV ON WORKLOAD GROUP 'g1' TO ROLE 'my_role';
允许 jack 查看 db1 下 view1 的创建语句
GRANT SHOW_VIEW_PRIV ON db1.view1 TO 'jack'@'%';
Keywords
GRANT