SET SESSION AUTHORIZATION
功能描述
把当前会话里的会话用户标识和当前用户标识都设置为指定的用户。
注意事项
只有在初始会话用户有系统管理员权限的时候,会话用户标识符才能改变。否则,只有在指定了被认证的用户名的情况下,系统才接受该命令。
语法格式
- 为当前会话设置会话用户标识符和当前用户标识符。
SET [ SESSION | LOCAL ] SESSION AUTHORIZATION role_name PASSWORD 'password';
- 重置会话和当前用户标识符为初始认证的用户名。
{SET [ SESSION | LOCAL ] SESSION AUTHORIZATION DEFAULT | SET SESSION_AUTHORIZATION = DEFAULT};
参数说明
- SESSION
声明这个命令只对当前会话起作用。
- LOCAL
声明该命令只在当前事务中有效。
- role_name
用户名。
取值范围:字符串,用户名要求详见•user_name。
- password
角色的密码。要求符合密码的命名规则。不支持直接使用密文密码。
- DEFAULT
重置会话和当前用户标识符为初始认证的用户名。
示例
--创建角色paul。 m_db=# CREATE ROLE paul IDENTIFIED BY '********'; --设置当前用户为paul。 m_db=# SET SESSION AUTHORIZATION paul password '********'; --查看当前用户。 m_db=# SELECT CURRENT_USER; --重置当前用户。 m_db=# SET SESSION_AUTHORIZATION = DEFAULT; --删除用户。 m_db=# DROP USER paul;