ALTER FOREIGN TABLE — 更改外部表的定义
ALTER FOREIGN TABLE [ IF EXISTS ] [ ONLY ]name
[ * ]action
[, ... ] ALTER FOREIGN TABLE [ IF EXISTS ] [ ONLY ]name
[ * ] RENAME [ COLUMN ]column_name
TOnew_column_name
ALTER FOREIGN TABLE [ IF EXISTS ]name
RENAME TOnew_name
ALTER FOREIGN TABLE [ IF EXISTS ]name
SET SCHEMAnew_schema
whereaction
is one of: ADD [ COLUMN ]column_name
data_type
[ COLLATEcollation
] [column_constraint
[ ... ] ] DROP [ COLUMN ] [ IF EXISTS ]column_name
[ RESTRICT | CASCADE ] ALTER [ COLUMN ]column_name
[ SET DATA ] TYPEdata_type
[ COLLATEcollation
] ALTER [ COLUMN ]column_name
SET DEFAULTexpression
ALTER [ COLUMN ]column_name
DROP DEFAULT ALTER [ COLUMN ]column_name
{ SET | DROP } NOT NULL ALTER [ COLUMN ]column_name
SET STATISTICSinteger
ALTER [ COLUMN ]column_name
SET (attribute_option
=value
[, ... ] ) ALTER [ COLUMN ]column_name
RESET (attribute_option
[, ... ] ) ALTER [ COLUMN ]column_name
SET STORAGE { PLAIN | EXTERNAL | EXTENDED | MAIN | DEFAULT } ALTER [ COLUMN ]column_name
OPTIONS ( [ ADD | SET | DROP ]option
['value
'] [, ... ]) ADDtable_constraint
[ NOT VALID ] VALIDATE CONSTRAINTconstraint_name
DROP CONSTRAINT [ IF EXISTS ]constraint_name
[ RESTRICT | CASCADE ] DISABLE TRIGGER [trigger_name
| ALL | USER ] ENABLE TRIGGER [trigger_name
| ALL | USER ] ENABLE REPLICA TRIGGERtrigger_name
ENABLE ALWAYS TRIGGERtrigger_name
SET WITHOUT OIDS INHERITparent_table
NO INHERITparent_table
OWNER TO {new_owner
| CURRENT_ROLE | CURRENT_USER | SESSION_USER } OPTIONS ( [ ADD | SET | DROP ]option
['value
'] [, ... ])
ALTER FOREIGN TABLE
更改现有外部表的定义。有几个子形式
ADD COLUMN
此形式向外部表添加新列,使用与 CREATE FOREIGN TABLE
相同的语法。与向常规表添加列的情况不同,底层存储不会发生任何变化:此操作只是声明现在可以通过外部表访问一些新列。
DROP COLUMN [ IF EXISTS ]
此形式从外部表中删除一列。如果表外有任何内容依赖于该列(例如视图),则需要使用 CASCADE
。如果指定了 IF EXISTS
并且该列不存在,则不会抛出错误。在这种情况下,会发出通知。
SET DATA TYPE
此形式更改外部表的列的类型。同样,这对任何底层存储都没有影响:此操作只是更改 PostgreSQL 认为该列具有的类型。
SET
/DROP DEFAULT
这些形式设置或删除列的默认值。默认值仅适用于后续的 INSERT
或 UPDATE
命令;它们不会导致表中已存在的行发生更改。
SET
/DROP NOT NULL
将列标记为允许或不允许空值。
SET STATISTICS
此形式设置后续 ANALYZE
操作的每列统计信息收集目标。有关更多详细信息,请参阅 ALTER TABLE
的类似形式。
SET ( attribute_option
= value
[, ... ] )
RESET ( attribute_option
[, ... ] )
此形式设置或重置每属性选项。有关更多详细信息,请参阅 ALTER TABLE
的类似形式。
SET STORAGE
此形式设置列的存储模式。有关更多详细信息,请参阅 ALTER TABLE
的类似形式。请注意,除非表的外部数据包装器选择关注它,否则存储模式无效。
ADD table_constraint
[ NOT VALID ]
此形式使用与 CREATE FOREIGN TABLE
相同的语法向外部表添加新约束。目前仅支持 CHECK
约束。
与向常规表添加约束的情况不同,不会进行任何操作来验证约束是否正确;相反,此操作只是声明应假定某些新条件对外部表中的所有行都成立。(请参阅 CREATE FOREIGN TABLE
中的讨论。)如果约束标记为 NOT VALID
,则不会假定它成立,而是仅记录下来以备将来使用。
VALIDATE CONSTRAINT
此形式将先前标记为 NOT VALID
的约束标记为有效。不会进行任何操作来验证约束,但是未来的查询将假定它成立。
DROP CONSTRAINT [ IF EXISTS ]
此形式删除外部表上指定的约束。如果指定了 IF EXISTS
并且约束不存在,则不会抛出错误。在这种情况下,会发出通知。
DISABLE
/ENABLE [ REPLICA | ALWAYS ] TRIGGER
这些形式配置属于外部表的触发器的触发。有关更多详细信息,请参阅 ALTER TABLE
的类似形式。
SET WITHOUT OIDS
用于删除 oid
系统列的向后兼容语法。由于不再可以添加 oid
系统列,因此这永远无效。
INHERIT parent_table
此形式将目标外部表添加为指定父表的新子表。有关更多详细信息,请参阅 ALTER TABLE
的类似形式。
NO INHERIT parent_table
此形式从指定父表的子表列表中删除目标外部表。
OWNER
此形式将外部表的所有者更改为指定的用户。
OPTIONS ( [ ADD | SET | DROP ] option
['value
'] [, ... ] )
更改外部表或其列之一的选项。ADD
、SET
和 DROP
指定要执行的操作。如果未显式指定任何操作,则假定为 ADD
。不允许重复的选项名称(尽管表选项和列选项具有相同的名称是可以的)。选项名称和值也使用外部数据包装器库进行验证。
RENAME
RENAME
形式更改外部表的名称或外部表中单个列的名称。
SET SCHEMA
此形式将外部表移动到另一个模式中。
除了 RENAME
和 SET SCHEMA
之外的所有操作都可以组合成一个列表,以并行应用多个更改。例如,可以在单个命令中添加多个列和/或更改多个列的类型。
如果该命令写为 ALTER FOREIGN TABLE IF EXISTS ...
并且该外部表不存在,则不会抛出错误。在这种情况下,会发出通知。
您必须拥有该表才能使用 ALTER FOREIGN TABLE
。要更改外部表的模式,您还必须对新模式具有 CREATE
权限。要更改所有者,您必须能够将 SET ROLE
设置为新的所有者角色,并且该角色必须对该表的模式具有 CREATE
权限。(这些限制强制执行更改所有者不会执行您无法通过删除和重新创建表来执行的操作。但是,超级用户无论如何都可以更改任何表的所有权。)要添加列或更改列类型,您还必须对数据类型具有 USAGE
权限。
name
要更改的现有外部表的名称(可能是模式限定的)。如果在表名称之前指定了 ONLY
,则仅更改该表。如果未指定 ONLY
,则更改该表及其所有后代表(如果有)。或者,可以在表名称后指定 *
以显式指示包含后代表。
column_name
新列或现有列的名称。
new_column_name
现有列的新名称。
new_name
表的新名称。
data_type
新列的数据类型,或现有列的新数据类型。
table_constraint
外部表的新表约束。
constraint_name
要删除的现有约束的名称。
CASCADE
自动删除依赖于已删除的列或约束的对象(例如,引用该列的视图),并反过来删除依赖于这些对象的所有对象(请参阅 第 5.15 节)。
RESTRICT
如果有任何依赖对象,则拒绝删除该列或约束。这是默认行为。
trigger_name
要禁用或启用的单个触发器的名称。
ALL
禁用或启用属于外部表的所有触发器。(如果任何触发器是内部生成的触发器,则这需要超级用户权限。核心系统不会向外部表添加此类触发器,但是附加代码可以这样做。)
USER
禁用或启用属于外部表的所有触发器,但内部生成的触发器除外。
parent_table
要与此外部表关联或取消关联的父表。
new_owner
表的新所有者的用户名。
new_schema
表将移动到的模式的名称。
关键词 COLUMN
是可忽略的噪声,可以省略。
当使用 ADD COLUMN
或 DROP COLUMN
添加或删除列,添加 NOT NULL
或 CHECK
约束,或者使用 SET DATA TYPE
更改列类型时,不会检查与外部服务器的一致性。用户有责任确保表定义与远程端匹配。
有关有效参数的详细描述,请参考 CREATE FOREIGN TABLE
。
将列标记为非空
ALTER FOREIGN TABLE distributors ALTER COLUMN street SET NOT NULL;
更改外部表的选项
ALTER FOREIGN TABLE myschema.distributors OPTIONS (ADD opt1 'value', SET opt2 'value2', DROP opt3);
ADD
、DROP
和 SET DATA TYPE
的形式符合 SQL 标准。其他形式是 PostgreSQL 对 SQL 标准的扩展。此外,在单个 ALTER FOREIGN TABLE
命令中指定多个操作也是一个扩展。
ALTER FOREIGN TABLE DROP COLUMN
可用于删除外部表的唯一列,从而留下一个零列表。这是 SQL 的扩展,SQL 不允许零列的外部表。
如果您在文档中发现任何不正确、与您使用特定功能的经验不符或需要进一步澄清的地方,请使用 此表单 报告文档问题。