PostgreSQL/Hologres 外部数据包装器系统表 pg_foreign_data_wrapper 详解

pg_foreign_data_wrapper 是 PostgreSQL 和 Hologres 中定义外部数据源连接器(FDW)的核心系统表,它存储了所有可用的外部数据包装器的元数据信息。

表结构定义解析

sql 复制代码
CREATE TABLE pg_catalog.pg_foreign_data_wrapper (
    fdwname name NOT NULL,      -- 外部数据包装器名称
    fdwowner oid NOT NULL,      -- 包装器所有者的OID
    fdwhandler oid NOT NULL,    -- 处理函数的OID
    fdwvalidator oid NOT NULL,  -- 验证函数的OID
    fdwacl aclitem[],           -- 访问权限控制列表
    fdwoptions text[]           -- 包装器级别的选项
) WITH OIDS;

字段详细说明

  1. fdwname (name类型,非空)
    • 外部数据包装器的名称(如'mysql_fdw', 'postgres_fdw')
    • 在创建外部服务器时引用此名称
  1. fdwowner (oid类型,非空)
    • 包装器所有者的OID,关联到pg_authid系统表
    • 所有者可以修改或删除此包装器
  1. fdwhandler (oid类型,非空)
    • 处理函数的OID,关联到pg_proc系统表
    • 该函数负责实际执行外部数据访问操作
  1. fdwvalidator (oid类型,非空)
    • 验证函数的OID,关联到pg_proc系统表
    • 用于验证服务器和表选项的有效性
  1. fdwacl (aclitem\[\]类型)
    • 访问控制列表,定义哪些用户/角色可以使用此包装器
    • 格式示例:{user1=U/user1,role1=U/admin}
  1. fdwoptions (text\[\]类型)
    • 包装器级别的全局选项,以键值对数组形式保存
    • 例如:{debug=true, batch_size='1000'}

外部数据架构层级

sql 复制代码
pg_foreign_data_wrapper (FDW定义)
  ↓
pg_foreign_server (服务器连接定义)
  ↓
pg_foreign_table (外部表定义)

实际应用示例

  1. 查询已安装的FDW
sql 复制代码
SELECT 
    fdwname AS wrapper_name,
    pg_get_userbyid(fdwowner) AS owner,
    fdwoptions
FROM pg_foreign_data_wrapper;
  1. 创建FDW的标准方法(推荐)
sql 复制代码
-- 安装扩展(如果FDW以扩展形式提供)
CREATE EXTENSION mysql_fdw;

-- 创建包装器
CREATE FOREIGN DATA WRAPPER mysql_fdw
HANDLER mysql_fdw_handler
VALIDATOR mysql_fdw_validator;
  1. 使用FDW创建外部服务器
sql 复制代码
CREATE SERVER mysql_server
FOREIGN DATA WRAPPER mysql_fdw
OPTIONS (host 'mysql.example.com', port '3306');

Hologres中的特殊说明

在阿里云Hologres中:

  1. 支持特定的外部数据源连接器,如连接MaxCompute的FDW
  2. 可能有预安装的专有FDW实现
  3. 某些功能可能与原生PostgreSQL有差异

重要安全警告

您代码中显示的DROP TABLECREATE TABLE语句是极其危险的操作:

  1. 绝对不要直接操作系统表,这会导致:
    • 数据库服务崩溃
    • 外部数据访问功能失效
    • 数据丢失风险
  1. 只应使用标准DDL命令管理FDW:
sql 复制代码
-- 创建包装器
CREATE FOREIGN DATA WRAPPER ... HANDLER ... VALIDATOR ...;

-- 删除包装器
DROP FOREIGN DATA WRAPPER IF EXISTS wrapper_name;
  1. 权限管理应使用:
sql 复制代码
GRANT USAGE ON FOREIGN DATA WRAPPER wrapper_name TO user_name;

典型FDW工作流程

  1. 安装FDW扩展(如mysql_fdw)
  2. 创建外部数据包装器
  3. 创建外部服务器(定义连接信息)
  4. 创建用户映射(定义认证信息)
  5. 创建外部表(定义表结构映射)
相关推荐
倔强的石头_10 小时前
《Kingbase护城河》——猎捕慢查询:执行计划的微观解析与索引调优实战
数据库
SelectDB12 小时前
Apache Doris Python UDF:让 SQL 直接调用 Python 生态,支撑 Agent 时代复杂业务逻辑
大数据·数据库·python
jiayou642 天前
KingbaseES 表级与列级加密完全指南
数据库·后端
GBASE2 天前
G术时刻 |GBase 8s数据库事务并发控制之封锁技术介绍(下)
数据库
xiezhr3 天前
逛GitHub发现了一款免费的带AI功能的数据库管理工具
数据库·ai编程·dba
吃糖的小孩4 天前
给 QQ AI 机器人设计“可控记忆”:会话摘要、手动长期记忆与角色卡边界
数据库
笃行3505 天前
金仓数据库数据安全双防线:静态存储加密与传输加密实战
数据库
笃行3505 天前
金仓数据库物理备份实战:sys_rman 全流程演练与误覆盖抢救
数据库
笃行3505 天前
金仓数据库逻辑备份实战:从全库导出到 Schema 替换的完整闭环
数据库