2025年9月25日: PostgreSQL 18 发布!
支持的版本: 当前18)/ 17 / 16 / 15 / 14 / 13
开发版本: devel
不支持的版本: 12 / 11 / 10 / 9.6 / 9.5 / 9.4 / 9.3 / 9.2 / 9.1 / 9.0 / 8.4

ALTER USER MAPPING

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_ROLECURRENT_USERUSER 匹配当前用户的名称。PUBLIC 用于匹配系统中所有现有和未来的用户名称。

server_name

用户映射的服务器名称。

OPTIONS ( [ ADD | SET | DROP ] option ['value'] [, ... ] )

更改用户映射的选项。新选项会覆盖之前指定的任何选项。ADDSETDROP 指定要执行的操作。如果没有显式指定操作,则假定为 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 MAPPINGDROP USER MAPPING 在相似的位置使用了 FOR,并且 IBM DB2(作为另一个主要的 SQL/MED 实现)也要求为 ALTER USER MAPPING 使用它,PostgreSQL 在这里为了保持一致性和互操作性而偏离了标准。

提交更正

如果您在文档中发现任何不正确、与您对特定功能的体验不符或需要进一步阐明之处,请使用 此表格 报告文档问题。