功能描述
设置当前会话的当前用户标识符。
注意事项
当前会话的用户必须是指定的rolename 角色的成员,
但系统管理员可以选择任何角色。
使用这条命令,它可能会增加一个用户的权限,也可能会限制一个用户的权限。如果会
话用户的角色有INHERITS 属性,则它自动拥有它能SET ROLE 变成的角色的所有权限;
在这种情况下,
SET ROLE 实际上是删除了所有直接赋予会话用户的权限,
以及它的所属角
色的权限,只剩下指定角色的权限。
另一方面,如果会话用户的角色有NOINHERITS 属性,
SET ROLE 删除直接赋予会话用户的权限,而获取指定角色的权限。
语法格式
GBase 8c SQL 参考手册
南大通用数据技术股份有限公司
1256
设置当前会话的当前用户标识符。
SET [ SESSION | LOCAL ] ROLE role_name PASSWORD 'password';
重置当前用户标识为当前会话用户标识符。
RESET ROLE;
参数说明
SESSION
声明这个命令只对当前会话起作用,此参数为缺省值。
LOCAL
声明该命令只在当前事务中有效。
role_name
角色名。
取值范围:字符串,要符合标识符的命名规范。
password
角色的密码。要求符合密码的命名规则。
RESET ROLE
用于重置当前用户标识。
示例
--创建角色paul。
gbase=#CREATE ROLE paul IDENTIFIED BY 'xxxxxxxxx';
--设置当前用户为paul。
gbase=#SET ROLE paul PASSWORD 'xxxxxxxxx';
--查看当前会话用户,当前用户。
gbase=#SELECT SESSION_USER, CURRENT_USER;
GBase 8c SQL 参考手册
南大通用数据技术股份有限公司
1257
--重置当前用户。
gbase=#RESET role;
--删除用户。
gbase=#DROP USER paul;