华为云云数据库GaussDBCREATE ROLE_云淘科技

功能描述

创建角色。

角色是拥有数据库对象和权限的实体。在不同的环境中角色可以认为是一个用户,一个组或者兼顾两者。

注意事项

在数据库中添加一个新角色,角色无登录权限。
创建角色的用户必须具备CREATE ROLE的权限或者是系统管理员。

语法格式

1
CREATE ROLE role_name [ [ WITH ] option [ ... ] ] [ ENCRYPTED | UNENCRYPTED ] { PASSWORD | IDENTIFIED BY } { 'password' [EXPIRED] | DISABLE };

其中角色信息设置子句option语法为:

 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
33
{SYSADMIN | NOSYSADMIN}
    | {MONADMIN | NOMONADMIN}
    | {OPRADMIN | NOOPRADMIN}
    | {POLADMIN | NOPOLADMIN}
    | {AUDITADMIN | NOAUDITADMIN}
    | {CREATEDB | NOCREATEDB}
    | {USEFT | NOUSEFT}
    | {CREATEROLE | NOCREATEROLE}
    | {INHERIT | NOINHERIT}
    | {LOGIN | NOLOGIN}
    | {REPLICATION | NOREPLICATION}
    | {INDEPENDENT | NOINDEPENDENT}
    | {VCADMIN | NOVCADMIN}
    | {PERSISTENCE | NOPERSISTENCE}
    | CONNECTION LIMIT connlimit
    | VALID BEGIN 'timestamp'
    | VALID UNTIL 'timestamp'
    | RESOURCE POOL 'respool'
    | USER GROUP 'groupuser'
    | PERM SPACE 'spacelimit'
    | TEMP SPACE 'tmpspacelimit'
    | SPILL SPACE 'spillspacelimit'
    | NODE GROUP logic_cluster_name
    | IN ROLE role_name [, ...]
    | IN GROUP role_name [, ...]
    | ROLE role_name [, ...]
    | ADMIN rol e_name [, ...]
    | USER role_name [, ...]
    | SYSID uid
    | DEFAULT TABLESPACE tablespace_name
    | PROFILE DEFAULT
    | PROFILE profile_name
    | PGUSER

参数说明

role_name

角色名称。

取值范围:字符串,要符合标识符命名规范,且最多为63个字符。若超过63个字符,数据库会截断并保留前63个字符当做角色名称。当角色名中包含大写字母时数据库会自动转换为小写字母,如果需要创建包含大写字母的角色名则需要使用双引号括起来。

password

登录密码。

密码规则如下:

密码默认不少于8个字符。
不能与角色名及角色名倒序相同。
至少包含大写字母(A-Z),小写字母(a-z),数字(0-9),非字母数字字符(限定为~!@#$%^&*()-_=+\|[{}];:,/?)四类字符中的三类字符。当密码中包含的字符不属于上述四种字符范围内时语句执行会报错。
密码也可以是符合格式要求的密文字符串,这种情况主要用于用户数据导入场景,不推荐用户直接使用。如果直接使用密文密码,用户需要知道密文密码对应的明文,并且保证明文密码复杂度,数据库不会校验密文密码复杂度,直接使用密文密码的安全性由用户保证。
创建角色时,应当使用单引号将用户密码括起来。

取值范围:不为空的字符串。

EXPIRED

在创建用户时可选EXPIRED,即创建密码失效用户,该用户不允许执行简单查询和扩展查询。只有在修改自身密码后才可正常执行语句。

DISABLE

默认情况下,用户可以更改自己的密码,除非密码被禁用。要禁用用户的密码,请指定DISABLE。禁用某个用户的密码后,将从系统中删除该密码,此类用户只能通过外部认证来连接数据库,例如:kerberos认证。只有管理员才能启用或禁用密码。普通用户不能禁用初始用户的密码。要启用密码,请运行ALTER USER并指定密码。

ENCRYPTED | UNENCRYPTED

控制密码存储在系统表里的口令是否加密。按照产品安全要求,密码必须加密存储,所以,UNENCRYPTED在GaussDB中禁止使用。因为系统无法对指定的加密口令字符串进行解密,所以如果目前的口令字符串已经是用SHA256加密的格式,则会继续照此存放,而不管是否声明了ENCRYPTED或UNENCRYPTED。这样就允许在dump/restore的时候重新加载加密的口令。

SYSADMIN | NOSYSADMIN

决定一个新角色是否为“系统管理员”,具有SYSADMIN属性的角色拥有系统最高权限。

缺省为NOSYSADMIN。

三权分立打开时,具有SYSADMIN属性的用户无权创建用户。

MONADMIN | NOMONADMIN

定义角色是否是监控管理员。

缺省为NOMONADMIN。

OPRADMIN | NOOPRADMIN

定义角色是否是运维管理员。

缺省为NOOPRADMIN。

POLADMIN | NOPOLADMIN

定义角色是否是安全策略管理员。

缺省为NOPOLADMIN。

AUDITADMIN | NOAUDITADMIN

定义角色是否有审计管理属性。

缺省为NOAUDITADMIN。

CREATEDB | NOCREATEDB

决定一个新角色是否能创建数据库。

新角色没有创建数据库的权限。

缺省为NOCREATEDB。

USEFT | NOUSEFT

该参数为保留参数,暂未启用。

CREATEROLE | NOCREATEROLE

决定一个角色是否可以创建新角色(也就是执行CREATE ROLE和CREATE USER)。 一个拥有CREATEROLE权限的角色也可以修改和删除其他角色。

缺省为NOCREATEROLE。

三权分立关闭时,具有CREATEROLE属性的用户有权限创建具有CREATEROLE、AUDITADMIN、MONADMIN、POLADMIN、CREATEDB属性的用户和普通用户。
三权分立打开时,具有CREATEROLE属性的用户有权限创建具有CREATEROLE、MONADMIN、POLADMIN、CREATEDB属性的用户和普通用户。

INHERIT | NOINHERIT

这些子句决定一个角色是否“继承”它所在组的角色的权限。不推荐使用。

LOGIN | NOLOGIN

具有LOGIN属性的角色才可以登录数据库。一个拥有LOGIN属性的角色可以认为是一个用户。

缺省为NOLOGIN。

REPLICATION | NOREPLICATION

定义角色是否允许流复制或设置系统为备份模式。REPLICATION属性是特定的角色,仅用于复制。

缺省为NOREPLICATION。

INDEPENDENT | NOINDEPENDENT

定义私有、独立的角色。具有INDEPENDENT属性的角色,管理员对其进行的控制、访问的权限被分离,具体规则如下:

未经INDEPENDENT角色授权,系统管理员无权对其表对象进行增、删、查、改、拷贝、授权操作。
若将私有用户表的相关权限授予其他非私有用户,系统管理员也会获得同样的权限。
未经INDEPENDENT角色授权,系统管理员和拥有CREATEROLE属性的安全管理员无权修改INDEPENDENT角色的继承关系。
系统管理员无权修改INDEPENDENT角色的表对象的属主。
系统管理员和拥有CREATEROLE属性的安全管理员无权去除INDEPENDENT角色的INDEPENDENT属性。
系统管理员和拥有CREATEROLE属性的安全管理员无权修改INDEPENDENT角色的数据库口令,INDEPENDENT角色需管理好自身口令,口令丢失无法重置。
管理员属性用户不允许定义修改为INDEPENDENT属性。
INDEPENDENT用户执行的操作会根据审计策略被计入审计日志。

VCADMIN | NOVCADMIN

定义逻辑集群管理员角色。具有逻辑集群管理员属性的角色,和普通用户相比,有如下额外权限:

在所关联逻辑集群(当前特性是实验室特性,使用时请联系华为工程师提供技术支持)中创建、修改和删除资源池的权限。
将所关联的逻辑集群的访问权限授予其他用户或角色,或回收其他用户或角色对关联逻辑集群的访问权限。

PERSISTENCE | NOPERSISTENCE

定义永久用户。仅允许初始用户创建、修改和删除具有PERSISTENCE属性的永久用户。

CONNECTION LIMIT

声明该角色可以使用的并发连接数量。

系统管理员不受此参数的限制。
connlimit每个CN单独统计,集群整体的连接数= connlimit * 当前正常CN节点个数。

取值范围:[-1, 2^31-1]的整数。缺省值为-1,表示没有限制。

VALID BEGIN

设置角色生效的时间戳。如果省略了该子句,角色无有效开始时间限制,timestamp为生效时间,格式为’YYYY-MM-DD HH:mm:ss’。

VALID UNTIL

设置角色失效的时间戳。如果省略了该子句,角色无有效结束时间限制,timestamp为失效时间,格式为’YYYY-MM-DD HH:mm:ss’。

RESOURCE POOL

设置角色使用的resource pool名称,该名称属于系统表:pg_resource_pool

USER GROUP ‘groupuser’

创建一个user的子用户。

PERM SPACE

设置用户使用空间的大小。

TEMP SPACE

设置用户临时表存储空间限额。

SPILL SPACE

设置用户算子落盘空间限额。

NODE GROUP

设置用户关联的逻辑集群(当前特性是实验室特性,使用时请联系华为工程师提供技术支持)名称。如果需要关联的逻辑集群名称包含大写字符或特殊字符,指定逻辑集群名称时需要加双引号。

IN ROLE

新角色立即拥有IN ROLE子句中列出的一个或多个现有角色拥有的权限。不推荐使用。

IN GROUP

IN GROUP是IN ROLE过时的拼法。不推荐使用。

ROLE

ROLE子句列出一个或多个现有的角色,它们将自动添加为这个新角色的成员,拥有新角色所有的权限。

ADMIN

ADMIN子句类似ROLE子句,不同的是ADMIN后的角色可以把新角色的权限赋给其他角色。

USER

USER子句是ROLE子句过时的拼法。

SYSID

SYSID子句将被忽略,无实际意义。

DEFAULT TABLESPACE

DEFAULT TABLESPACE子句将被忽略,无实际意义。

PROFILE

PROFILE子句将被忽略,无实际意义。

PGUSER

当前版本该属性没有实际意义,仅为了语法的前向兼容而保留。

示例

 1
 2
 3
 4
 5
 6
 7
 8
 9
10
11
12
13
14
15
16
17
--创建一个角色,名为manager,密码为********。
gaussdb=# CREATE ROLE manager IDENTIFIED BY '********';

--创建一个角色,从2015年1月1日开始生效,到2026年1月1日失效。
gaussdb=# CREATE ROLE miriam WITH LOGIN PASSWORD '********' VALID BEGIN '2015-01-01' VALID UNTIL '2026-01-01';

--修改角色manager的密码为**********。
gaussdb=# ALTER ROLE manager IDENTIFIED BY '**********' REPLACE '********';

--修改角色manager为系统管理员。
gaussdb=# ALTER ROLE manager SYSADMIN;

--删除角色manager。
gaussdb=# DROP ROLE manager;

--删除角色miriam。
gaussdb=# DROP ROLE miriam;

相关链接

SET ROLE,ALTER ROLE,DROP ROLE,GRANT,REVOKE

父主题: SQL语法

同意关联代理商云淘科技,购买华为云产品更优惠(QQ 78315851)

内容没看懂? 不太想学习?想快速解决? 有偿解决: 联系专家