CREATE SERVER

功能描述

定义一个新的外部服务器。

语法格式

  1. CREATE SERVER server_name
  2. FOREIGN DATA WRAPPER fdw_name
  3. OPTIONS ( { option_name ' value ' } [, ...] ) ;

参数说明

  • server_name

    server的名称。

    取值范围:长度必须小于等于63。

  • fdw_name

    指定外部数据封装器的名称。

    取值范围:oracle_fdw,mysql_fdw,postgres_fdw,file_fdw,mot_fdw。

  • OPTIONS ( { option_name ‘ value ‘ } [, …] )

    这个子句为服务器指定选项。这些选项通常定义该服务器的连接细节,但是实际的名称和值取决于该服务器的外部数据包装器。

    • oracle_fdw支持的options包括:

      • dbserver

        远端Oracle数据库的连接字符串。

      • isolation_level (默认值为serializable)

        oracle数据库的事务隔离级别。

        取值范围:serializable, read_committed , read_only

    • mysql_fdw支持的options包括:

      • host (默认值为 127.0.0.1)

        MySQL Server/MariaDB的地址。

      • port (默认值为 3306)

        MySQL Server/MariaDB侦听的端口号。

    • postgres_fdw支持的options同libpq支持的连接参数一致,可参考 链接字符 。需要注意的是,以下几个options不支持设置:

      • userpassword

        用户名和密码将在创建user mapping时指定。

      • client_encoding

        将自动获取本地server的编码方式并设置该值。

      • application_name

        总是设置成postgres_fdw。

    • 用于指定外部服务器的各类参数,详细的参数说明如下所示。

      • encrypt

        是否对数据进行加密,该参数仅支持type为OBS时设置。默认值为on。

        取值范围:

        • on表示对数据进行加密,使用HTTPS协议通信。
        • off表示不对数据进行加密,使用HTTP协议通信。
      • access_key

        OBS访问协议对应的AK值(OBS云服务界面由用户获取),创建外表时AK值会加密保存到数据库的元数据表中。该参数仅支持type为OBS时设置。

      • secret_access_key

        OBS访问协议对应的SK值(OBS云服务界面由用户获取),创建外表时SK值会加密保存到数据库的元数据表中。该参数仅支持type为OBS时设置。

除了libpq支持的连接参数外,还额外提供3个options:

  • use_remote_estimate

    控制postgres_fdw是否发出EXPLAIN命令以获取运行消耗估算。默认值为false。

  • fdw_startup_cost

    执行一个外表扫描时的启动耗时估算。这个值通常包含建立连接、远端对请求的分析和生成计划的耗时。默认值为100。

  • fdw_typle_cost

    在远端服务器上对每一个元组进行扫描时的额外消耗。这个值通常表示数据在server间传输的额外消耗。默认值为0.01。

示例

创建server。

  1. openGauss=* create server my_server foreign data wrapper log_fdw;
  2. CREATE SERVER

相关链接

ALTER SERVERDROP SERVER