更新时间:2025-08-04 GMT+08:00
分享

SET SESSION AUTHORIZATION

功能描述

把当前会话里的会话用户标识和当前用户标识都设置为指定的用户。

注意事项

只有在初始会话用户有系统管理员权限的时候,会话用户标识符才能改变。否则,只有在指定了被认证的用户名的情况下,系统才接受该命令。

语法格式

  • 为当前会话设置会话用户标识符和当前用户标识符。
    1
    SET [ SESSION | LOCAL ] SESSION AUTHORIZATION role_name PASSWORD '{password}';
    
  • 重置会话和当前用户标识符为初始认证的用户名。
    1
    2
    {SET [ SESSION | LOCAL ] SESSION AUTHORIZATION DEFAULT
        | RESET SESSION AUTHORIZATION};
    

参数说明

表1 SET SESSION AUTHORIZATION参数说明

参数

描述

取值范围

SESSION

声明这个命令只对当前会话起作用。

-

LOCALE

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

-

role_name

角色名。

已存在的角色名。

password

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

-

DEFAULT

重置会话和当前用户标识符为初始认证的用户名。

-

示例

设置当前用户为paul。

1
SET SESSION AUTHORIZATION paul password '{password}';

查看当前会话用户,当前用户。

1
SELECT SESSION_USER, CURRENT_USER;

重置当前用户。

1
RESET SESSION AUTHORIZATION;

相关参考

SET ROLE

相关文档