ALTER USER MAPPING — 更改用户映射的定义
ALTER USER MAPPING FOR { user_name | USER | CURRENT_ROLE | CURRENT_USER | SESSION_USER | PUBLIC }
SERVER server_name
OPTIONS ( [ ADD | SET | DROP ] option ['value'] [, ... ] )
ALTER USER MAPPING 更改用户映射的定义。
一个外部服务器的所有者可以更改该服务器下任何用户的用户映射。此外,如果用户已被授予对该服务器的 USAGE 权限,则用户可以更改其自己用户名的用户映射。
user_name映射的用户名称。CURRENT_ROLE、CURRENT_USER 和 USER 匹配当前用户的名称。PUBLIC 用于匹配系统中所有现有和未来的用户名称。
server_name用户映射的服务器名称。
OPTIONS ( [ ADD | SET | DROP ] option ['value'] [, ... ] )更改用户映射的选项。新选项会覆盖之前指定的任何选项。ADD、SET 和 DROP 指定要执行的操作。如果没有显式指定操作,则假定为 ADD。选项名称必须是唯一的;选项也会由服务器的外部数据包装器进行验证。
更改用户映射 bob,服务器 foo 的密码
ALTER USER MAPPING FOR bob SERVER foo OPTIONS (SET password 'public');
ALTER USER MAPPING 符合 ISO/IEC 9075-9 (SQL/MED)。有一个细微的语法问题:标准中省略了 FOR 关键字。由于 CREATE USER MAPPING 和 DROP USER MAPPING 在相似的位置使用了 FOR,并且 IBM DB2(作为另一个主要的 SQL/MED 实现)也要求为 ALTER USER MAPPING 使用它,PostgreSQL 在这里为了保持一致性和互操作性而偏离了标准。