IMPORT FOREIGN SCHEMA — 从一个外部服务器导入表定义
IMPORT FOREIGN SCHEMAremote_schema[ { LIMIT TO | EXCEPT } (table_name[, ...] ) ] FROM SERVERserver_nameINTOlocal_schema[ OPTIONS (option'value' [, ... ] ) ]
IMPORT FOREIGN SCHEMA创建外部表,用来表示存在于外部服务器上的表。新的外部表将归发出该命令的用户所有,并使用与远程表相匹配的正确列定义和选项创建。
默认情况下,外部服务器上某个特定模式中的所有表和视图都会被导入。也可以把待导入表的列表限制为指定的子集,或者排除某些特定表。新的外部表都会创建在目标模式中,该模式必须已经存在。
要使用IMPORT FOREIGN SCHEMA,用户必须在外部服务器上拥有USAGE权限,并在目标模式上拥有CREATE权限。
remote_schema要从中导入的远程模式。远程模式的具体含义取决于所使用的外部数据包装器。
LIMIT TO ( table_name [, ...] )只导入名称与给定表名之一匹配的外部表。远程模式中的其他表将被忽略。
EXCEPT ( table_name [, ...] )将指定的外部表排除在导入之外。除这里列出的表外,远程模式中的其他表都会被导入。
server_name要从中导入的外部服务器。
local_schema将在其中创建所导入外部表的模式。
OPTIONS ( option 'value' [, ...] )导入期间要使用的选项。允许的选项名和值取决于各个外部数据包装器。
从服务器film_server上的远程模式foreign_films导入表定义,并在本地模式films中创建这些外部表:
IMPORT FOREIGN SCHEMA foreign_films
FROM SERVER film_server INTO films;
与上例相同,但只导入actors和directors这两个表(如果它们存在):
IMPORT FOREIGN SCHEMA foreign_films LIMIT TO (actors, directors)
FROM SERVER film_server INTO films;
IMPORT FOREIGN SCHEMA命令符合SQL标准,但OPTIONS子句是PostgreSQL扩展。
如果您发现文档中有不正确的内容、与您使用特定功能的经验不符或需要进一步说明,请使用此表单来报告文档问题。