tds_fdw

TDS 数据库(Sybase/SQL Server)外部数据包装器

概览

扩展包名版本分类许可证语言
tds_fdw2.0.5FDWPostgreSQLC
ID扩展名BinLibLoadCreateTrustReloc模式
8620tds_fdw-
相关扩展mysql_fdw oracle_fdw babelfishpg_tsql babelfishpg_tds wrappers odbc_fdw jdbc_fdw db2_fdw

版本

类型仓库版本PG 大版本包名依赖
EXTPGDG2.0.51817161514tds_fdw-
RPMPGDG2.0.51817161514tds_fdw_$v-
DEBPGDG2.0.51817161514postgresql-$v-tds-fdw-
OS / PGPG18PG17PG16PG15PG14
el8.x86_64
el8.aarch64
el9.x86_64
el9.aarch64
el10.x86_64
el10.aarch64
d12.x86_64
d12.aarch64
d13.x86_64
d13.aarch64
u22.x86_64
u22.aarch64
u24.x86_64
u24.aarch64
u26.x86_64
u26.aarch64

安装

您可以直接安装 tds_fdw 扩展包的预置二进制包,首先确保 PGDG 仓库已经添加并启用:

pig repo add pgdg -u          # 添加 PGDG 仓库并更新缓存

使用 pig 或者是 apt/yum/dnf 安装扩展:

pig install tds_fdw;          # 当前活跃 PG 版本安装
pig ext install -y tds_fdw -v 18  # PG 18
pig ext install -y tds_fdw -v 17  # PG 17
pig ext install -y tds_fdw -v 16  # PG 16
pig ext install -y tds_fdw -v 15  # PG 15
pig ext install -y tds_fdw -v 14  # PG 14
dnf install -y tds_fdw_18       # PG 18
dnf install -y tds_fdw_17       # PG 17
dnf install -y tds_fdw_16       # PG 16
dnf install -y tds_fdw_15       # PG 15
dnf install -y tds_fdw_14       # PG 14
apt install -y postgresql-18-tds-fdw   # PG 18
apt install -y postgresql-17-tds-fdw   # PG 17
apt install -y postgresql-16-tds-fdw   # PG 16
apt install -y postgresql-15-tds-fdw   # PG 15
apt install -y postgresql-14-tds-fdw   # PG 14

创建扩展

CREATE EXTENSION tds_fdw;

用法

tds_fdw 是一个 foreign data wrapper,用于通过 FreeTDS 等 DB-Library 实现查询 Sybase 和 Microsoft SQL Server 等 TDS 数据库。

创建服务器

CREATE EXTENSION tds_fdw;

CREATE SERVER mssql_svr
  FOREIGN DATA WRAPPER tds_fdw
  OPTIONS (servername '127.0.0.1', port '1433',
           database 'tds_fdw_test', tds_version '7.1');

服务器选项: servername(服务器地址或 DSN,支持逗号分隔 failover list)、portdatabasedbuse(0 表示 direct connection,非 0 表示 dbuse())、tds_version(protocol version)、languagecharacter_setmsg_handlernoticeblackhole)、sqlserver_ansi_modefdw_startup_costfdw_tuple_cost

创建用户映射

CREATE USER MAPPING FOR postgres
  SERVER mssql_svr
  OPTIONS (username 'sa', password 'secret');

对于 Azure SQL databases,username 选项使用 username@servername 格式。

创建外部表

直接映射远端表:

CREATE FOREIGN TABLE mssql_table (
  id integer,
  name varchar(255),
  value numeric(10,2)
)
SERVER mssql_svr
OPTIONS (schema_name 'dbo', table_name 'mytable');

或使用自定义 SQL 查询:

CREATE FOREIGN TABLE mssql_query (
  id integer,
  name varchar(255),
  total numeric(10,2)
)
SERVER mssql_svr
OPTIONS (query 'SELECT id, name, SUM(amount) AS total FROM orders GROUP BY id, name');

表选项: table_namequery(二者必选其一,且互斥)、schema_namematch_column_names(按名称还是按位置映射)、use_remote_estimatelocal_tuple_estimaterow_estimate_methodexecuteshowplan_all)。

列选项: column_name(远端列名不同于本地列名时使用)。

查询与调试

SELECT * FROM mssql_table WHERE id > 100;

-- View the remote query sent to SQL Server
EXPLAIN (VERBOSE) SELECT * FROM mssql_table WHERE id > 100;

导入外部模式

IMPORT FOREIGN SCHEMA dbo
  FROM SERVER mssql_svr
  INTO public
  OPTIONS (import_default 'true');

导入选项: import_defaultimport_not_null,以及 keep_custom_types,后者用于在已存在匹配 PostgreSQL domains 时保留 Sybase user-defined types。

Planner 与运行时说明

上游 README 说明当前版本不支持 join pushdown 或写操作。当 match_column_names 启用时,它支持 WHERE 和列下推。

使用 PostgreSQL SET 设置诊断 memory-stat variables,例如:

SET tds_fdw.show_finished_memory_stats = 1;

可用变量包括 tds_fdw.show_before_row_memory_statstds_fdw.show_after_row_memory_statstds_fdw.show_finished_memory_stats

Pigsty package metadata 是来自 PGDG 的版本 2.0.5,覆盖 PostgreSQL 14-18。上游文档说该 FDW 应支持 PostgreSQL 9.2+,当前 build matrix 包含 PostgreSQL 13-18,但此 stub 遵循 db/extension.csv 中的已打包 PostgreSQL 版本。


最后修改 2026-05-18: routine extension update (ac43610)