5.2.?角色属性

一个数据库角色可以有一些属性,它们定义角色的权限并且与客户端认证系统交互。

login privilege

只有具有LOGIN属性的角色才能被用于一个数据库连接的初始角色名称。一个带有LOGIN属性的角色可以被认为和一个数据库用户相同。要创建一个带有登录权限的角色,使用下列两个命令之一:

CREATE ROLE name LOGIN;
CREATE USER name;

(除了CREATE USER默认假定有LOGIN之外,CREATE USERCREATE ROLE等效)。

superuser status

一个数据库超级用户会绕开所有权限检查,除了登录的权限。这是一个危险的权限并且应该小心使用,最好用一个不是超级用户的角色来完成你的大部分工作。要创建一个新数据库超级用户,使用CREATE ROLE name SUPERUSER。你必须作为一个超级用户来完成这些。

database creation

一个角色必须被显式给予权限才能创建数据库(除了超级用户,因为它们会绕开所有权限检查)。要创建这样一个角色,使用CREATE ROLE name CREATEDB

role creation

一个角色必须被显式给予权限才能创建更多角色(除了超级用户,因为它们会绕开所有权限检查)。要创建这样一个角色,使用CREATE ROLE name CREATEROLE。一个带有CREATEROLE权限的角色也可以修改和删除其他角色,还可以授予或回收角色中的成员关系。然而,要创建、修改、删除一个超级用户角色的成员关系,需要以超级用户的身份操作,CREATEROLE不足以完成这一切。

initiating replication

一个角色必须被显式给予权限才能发起流复制(除了超级用户,因为它们会绕开所有权限检查)。一个被用于流复制的角色必须也具有LOGIN权限。要创建这样一个角色,使用CREATE ROLE name REPLICATION LOGIN

password

只有当客户端认证方法要求用户在连接数据库时提供一个口令时,口令才有意义。passwordmd5认证方法使用口令。数据库口令与操作系统命令独立。在角色创建时指定一个口令:CREATE ROLE name PASSWORD 'string'

在创建后可以用ALTER ROLE修改一个角色属性。

提示

推荐创建一个具有CREATEDBCREATEROLE权限的角色,而不是创建一个超级用户,并且然后用这个角色来完成对数据库和角色的例行管理。这种方法避免了在非必要时作为超级用户操作任务的风险。

对于第?3?章中描述的运行时配置设置,一个角色也可以针对自身为运行时的配置设置默认项。例如,如果出于某些原因你希望在每次连接时禁用索引扫描(不建议这样操作),你可以使用:

ALTER ROLE myname SET enable_indexscan TO off;

这将保存设置(但是不会立刻设置)。等同于在这个角色的后续连接中,会话开始之前执行SET enable_indexscan TO off。你也可以在会话期间改变该设置,它将只是作为默认值。要移除一个角色相关的默认设置,使用ALTER ROLE rolename RESET varname。注意附加到没有LOGIN权限的角色的角色相关默认值没有意义,因为它们从不会被调用。

XML 地图 | Sitemap 地图