绑定完请刷新页面
取消
刷新

分享好友

×
取消 复制
SQL语法-SET ROLE
2020-01-16 13:47:18

功能描述

设置当前会话的当前用户标识符。

注意事项

  • 当前会话的用户必须是指定的rolename角色的成员,但系统管理员可以选择任何角色。
  • 使用这条命令,它可能会增加一个用户的权限,也可能会限制一个用户的权限。如果会话用户的角色有INHERITS属性,则它自动拥有它能SET ROLE变成的角色的所有权限;在这种情况下,SET ROLE实际上是删除了所有直接赋予会话用户的权限,以及它的所属角色的权限,只剩下指定角色的权限。另一方面,如果会话用户的角色有NOINHERITS属性,SET ROLE删除直接赋予会话用户的权限,而获取指定角色的权限。

语法格式

  • 设置当前会话的当前用户标识符。
    SET [ SESSION | LOCAL ] ROLE role_name PASSWORD 'password';
    重置当前用户标识为当前会话用户标识符。
  • RESET ROLE;
    参数说明
  • SESSION

    声明这个命令只对当前会话起作用,此参数为缺省值。

    取值范围:字符串,要符合标识符的命名规范。

  • LOCALE

    声明该命令只在当前事务中有效。

  • role_name

    角色名。

    取值范围:字符串,要符合标识符的命名规范。

  • password

    角色的密码。要求符合密码的命名规则。

  • RESET ROLE

    用于重置当前用户标识。

示例

--创建角色paul。
CREATE ROLE paul IDENTIFIED BY 'Bigdata123@';
--设置当前用户为paul。
SET ROLE paul PASSWORD 'Bigdata123@';
--查看当前会话用户,当前用户。
SELECT SESSION_USER, CURRENT_USER;
--重置当前用户。
RESET role;
--删除用户。
DROP USER paul;


分享好友

分享这个小栈给你的朋友们,一起进步吧。

GaussDB_数据库
创建时间:2020-01-06 16:21:44
华为GaussDB数据库小栈
展开
订阅须知

• 所有用户可根据关注领域订阅专区或所有专区

• 付费订阅:虚拟交易,一经交易不退款;若特殊情况,可3日内客服咨询

• 专区发布评论属默认订阅所评论专区(除付费小栈外)

技术专家

查看更多
  • GaussDB_数据库
    专家
戳我,来吐槽~