db2fce

为 PostgreSQL 提供 DB2 兼容函数、类型、操作符与 SYSIBM.SYSDUMMY1。

概览

扩展包名版本分类许可证语言
db2fce0.0.17SIMPostgreSQLSQL
ID扩展名BinLibLoadCreateTrustReloc模式
9200db2fcedb2
相关扩展plpgsql orafce pg_dbms_metadata pg_dbms_job

PGDG APT is complete for PG14-18; Pigsty RPM noarch spec fills the PGDG YUM gap for PG14-18.

版本

类型仓库版本PG 大版本包名依赖
EXTMIXED0.0.171817161514db2fceplpgsql
RPMPIGSTY0.0.171817161514db2fce_$v-
DEBPGDG0.0.171817161514postgresql-$v-db2fce-
OS / PGPG18PG17PG16PG15PG14
el8.x86_64
el8.aarch64
el9.x86_64
el9.aarch64
el10.x86_64
el10.aarch64
d12.x86_64
PGDG 0.0.17
PGDG 0.0.17
PGDG 0.0.17
PGDG 0.0.17
PGDG 0.0.17
d12.aarch64
PGDG 0.0.17
PGDG 0.0.17
PGDG 0.0.17
PGDG 0.0.17
PGDG 0.0.17
d13.x86_64
PGDG 0.0.17
PGDG 0.0.17
PGDG 0.0.17
PGDG 0.0.17
PGDG 0.0.17
d13.aarch64
PGDG 0.0.17
PGDG 0.0.17
PGDG 0.0.17
PGDG 0.0.17
PGDG 0.0.17
u22.x86_64
PGDG 0.0.17
PGDG 0.0.17
PGDG 0.0.17
PGDG 0.0.17
PGDG 0.0.17
u22.aarch64
PGDG 0.0.17
PGDG 0.0.17
PGDG 0.0.17
PGDG 0.0.17
PGDG 0.0.17
u24.x86_64
PGDG 0.0.17
PGDG 0.0.17
PGDG 0.0.17
PGDG 0.0.17
PGDG 0.0.17
u24.aarch64
PGDG 0.0.17
PGDG 0.0.17
PGDG 0.0.17
PGDG 0.0.17
PGDG 0.0.17
u26.x86_64
PGDG 0.0.17
PGDG 0.0.17
PGDG 0.0.17
PGDG 0.0.17
PGDG 0.0.17
u26.aarch64
PGDG 0.0.17
PGDG 0.0.17
PGDG 0.0.17
PGDG 0.0.17
PGDG 0.0.17

构建

您可以使用 pig build 命令构建 db2fce 扩展的 RPM / DEB 包:

pig build pkg db2fce         # 构建 RPM / DEB 包

安装

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

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

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

pig install db2fce;          # 当前活跃 PG 版本安装
pig ext install -y db2fce -v 18  # PG 18
pig ext install -y db2fce -v 17  # PG 17
pig ext install -y db2fce -v 16  # PG 16
pig ext install -y db2fce -v 15  # PG 15
pig ext install -y db2fce -v 14  # PG 14
dnf install -y db2fce_18       # PG 18
dnf install -y db2fce_17       # PG 17
dnf install -y db2fce_16       # PG 16
dnf install -y db2fce_15       # PG 15
dnf install -y db2fce_14       # PG 14
apt install -y postgresql-18-db2fce   # PG 18
apt install -y postgresql-17-db2fce   # PG 17
apt install -y postgresql-16-db2fce   # PG 16
apt install -y postgresql-15-db2fce   # PG 15
apt install -y postgresql-14-db2fce   # PG 14

创建扩展

CREATE EXTENSION db2fce CASCADE;  -- 依赖: plpgsql

用法

来源:READMESQL objectscontrol file

db2fce 为 PostgreSQL 提供 DB2 兼容环境。它创建 DB2 风格的函数、类型、操作符,以及 SYSIBM.SYSDUMMY1 兼容视图,便于迁移或适配原本面向 IBM Db2 的 SQL。

启用

CREATE EXTENSION db2fce;

SET search_path = db2, sysibm, public;

大多数兼容对象位于 db2 schema,sysibm.sysdummy1 用于兼容需要 dummy 单行表的 DB2 查询。

SELECT * FROM sysibm.sysdummy1;

兼容函数

db2 schema 包含日期时间函数,例如 microsecondsecondminutehourdaymonthyeardaysmonths_betweendatetimetimestamp_format

字符串和转换函数包括 locatetranslatelcaseupperlowerstripcharintegerintdoubledecimaldechexrounddigitsvalue

操作符

SQL 层还定义了 DB2 风格操作符,例如用于不等比较的 ^=,以及多种类型上的拼接操作符 !!

SELECT db2.int('42');
SELECT db2.days(current_date);
SELECT 'db' !! '2';

注意事项

db2 加入 search_path 后,很多 DB2 函数调用可以不带 schema 前缀。部分与 PostgreSQL 语法或内置行为冲突的名称,仍然需要显式写成 db2. 前缀。


最后修改 2026-07-02: extension update 2026-07-02 (d4da20c)