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. 创建外部表(定义表结构映射)
相关推荐
锋君1 分钟前
Orcale数据库在Asp.Net Core环境下使用EF Core 生成实体
数据库·后端·oracle·asp.net
啊吧怪不啊吧2 分钟前
SQL之用户管理——权限与用户
大数据·数据库·sql
VX:Fegn08953 分钟前
计算机毕业设计|基于springboot + vue电影院购票管理系统(源码+数据库+文档)
数据库·vue.js·spring boot·后端·课程设计
NineData8 分钟前
NineData 数据库 DevOps 正式支持谷歌云,全面接入 GCP 数据源
运维·数据库·devops·ninedata·gcp·玖章算术·数据智能管理平台
韩立学长14 分钟前
Springboot考研自习室预约管理系统1wdeuxh6(程序、源码、数据库、调试部署方案及开发环境)系统界面展示及获取方式置于文档末尾,可供参考。
数据库·spring boot·后端
2503_9284115618 分钟前
12.18 中后台项目-权限管理
前端·javascript·数据库
云和恩墨2 小时前
OceanBase企业版会话级SQL跟踪实操:DBMS_MONITOR(类Oracle 10046事件)
数据库·sql·oracle·oceanbase
为什么不问问神奇的海螺呢丶2 小时前
oracle 数据库巡检 sql
数据库·sql·oracle
麦麦鸡腿堡2 小时前
MySQL数据库操作指令
数据库·mysql
陈天伟教授8 小时前
人工智能训练师认证教程(2)Python os入门教程
前端·数据库·python